Можем ли мы использовать JSch для связи на основе ключей SSH? - PullRequest
38 голосов
/ 08 февраля 2011

Я использую JSch для связи по sftp, теперь я хочу использовать упрощение аутентификации на основе ключей, ключ загружается на клиентскую и серверную машину один раз моей сетевой командой, и все последующее общение будет только пользовательским на основании которого мы загрузили ключ.

sftp -oPort=10022 jmark@192.18.0.246

как tjill@192.18.0.135

как эта команда отлично работает и подключается к sftp, как я могу достичь этой функциональности программно.

если невозможно использовать JSch, предложите какую-нибудь другую библиотеку. Я наткнулся на Apache SSHD .

1 Ответ

87 голосов
/ 08 февраля 2011

Это возможно. Посмотрите на JSch.addIdentity(...)

Это позволяет использовать ключ либо как байтовый массив, либо для чтения его из файла.

import com.jcraft.jsch.Channel;
import com.jcraft.jsch.ChannelSftp;
import com.jcraft.jsch.JSch;
import com.jcraft.jsch.Session;

public class UserAuthPubKey {
    public static void main(String[] arg) {
        try {
            JSch jsch = new JSch();

            String user = "tjill";
            String host = "192.18.0.246";
            int port = 10022;
            String privateKey = ".ssh/id_rsa";

            jsch.addIdentity(privateKey);
            System.out.println("identity added ");

            Session session = jsch.getSession(user, host, port);
            System.out.println("session created.");

            // disabling StrictHostKeyChecking may help to make connection but makes it insecure
            // see http://stackoverflow.com/questions/30178936/jsch-sftp-security-with-session-setconfigstricthostkeychecking-no
            // 
            // java.util.Properties config = new java.util.Properties();
            // config.put("StrictHostKeyChecking", "no");
            // session.setConfig(config);

            session.connect();
            System.out.println("session connected.....");

            Channel channel = session.openChannel("sftp");
            channel.setInputStream(System.in);
            channel.setOutputStream(System.out);
            channel.connect();
            System.out.println("shell channel connected....");

            ChannelSftp c = (ChannelSftp) channel;

            String fileName = "test.txt";
            c.put(fileName, "./in/");
            c.exit();
            System.out.println("done");

        } catch (Exception e) {
            System.err.println(e);
        }
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...