java jsch 密钥登陆_我们可以使用JSch进行基于SSH密钥的通信吗?

有可能的。看一下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);

}

}

}


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部