我试图将JSch与私钥配置一起使用。我使用PuTTYgen生成了公钥和私钥,但我不确定如何处理这两个文件。
哪个密钥(公共/私人)需要转移到服务器?
答案 0 :(得分:3)
首先,您需要在服务器上注册PuTTYgen生成的 public 键。请参阅Getting ready for public key authentication或(我的)Set up SSH public key authentication。
最后,请参阅Can we use JSch for SSH key-based communication?了解有关在JSch中使用私有键的详细信息。
确保使用最新版本的JSch,因为旧版本本身不支持.ppk格式。
答案 1 :(得分:1)
使用PuTTy私钥(.ppk)进行连接的代码段
JSch jsch=new JSch();
jsch.setKnownHosts("~\.ssh\know_hosts");
jsch.addIdentity("~\sshkey.ppk");
Session session=jsch.getSession("ec2-user", "54.12.11.90", 22);
session.setConfig("PreferredAuthentications", "publickey");
session.setConfig("StrictHostKeyChecking", "no");
session.connect();
Channel channel=session.openChannel("shell");
channel.setInputStream(System.in);
channel.setOutputStream(System.out);
channel.connect(3*1000);
使用了Jsch的0.1.54版本
<dependency>
<groupId>com.jcraft</groupId>
<artifactId>jsch</artifactId>
<version>0.1.54</version>
</dependency>