繁体   English   中英

使用JSch通过jumphost连接到远程主机时“拒绝HostKey”

[英]“reject HostKey” when connecting to remote host through jumphost with JSch

需要通过jumphost SSH到目标主机。 曾尝试过在JSch JumpHosts示例中提到的相同内容

Session[] sessions = new Session[2];
Session session = null;

sessions[0] = session = jsch.getSession(getUserName(), "jumphost1.com", 22);
session.setPassword(getHostPassword());
UserInfo userInfo = new UserInfo();
userInfo.setPassword(getHostPassword());
session.setUserInfo(userInfo);
Properties prop = new Properties();
prop.put("StrictHostKeyChecking", "no");
prop.put("PreferredAuthentications", "publickey,keyboard-interactive,password");
session.setConfig(prop);
session.connect();

String host = "host1.com";
int assignedPort = session.setPortForwardingL(0, host, 22);
LOGGER.info("Jump host the {} of agent {} and port forwarding {}", i, host, assignedPort);

sessions[i] = session = jsch.getSession(getUserName(), "127.0.0.1", assignedPort);
session.setPassword(getHostPassword());
userInfo = new UserInfo();
userInfo.setPassword(getHostPassword());
session.setUserInfo(userInfo);
session.setHostKeyAlias(host);
session.connect();

连接到目标主机时获得以下异常:

Caused by: com.jcraft.jsch.JSchException: reject HostKey: 127.0.0.1
    at com.jcraft.jsch.Session.checkHost(Session.java:799)
    at com.jcraft.jsch.Session.connect(Session.java:345)
    at com.jcraft.jsch.Session.connect(Session.java:183)

我试图登录到主机host1.com通过jumphost1.com

  • 登录到jumphost1.com
  • 然后是ssh host1.com
  • 执行host1的命令

您通过jumphost连接的代码是正确的。

唯一的问题是您的本地主机密钥存储库包含第二个主机的不同主机密钥,而不是您从真实(第二个)主机接收的主机密钥。

你实际上似乎并不关心安全性 ,因为你为jumphost会话设置了StrictHostKeyChecking=no官方的例子没有做到这一点!)。 但是你没有为第二个会话做同样的事情,因此错误。

另请参阅如何使用JSch SFTP库解析Java UnknownHostKey?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM