我正在尝试使用j2ssh将文件从我的应用程序SCP发送到服务器。远程服务器正在运行TECTIA。
在命令行(部署了我的应用程序的Solaris计算机)上,scp使用我们交换的密钥对可以正常工作。
在我的应用程序中,j2ssh无法建立连接,引发异常:
Caused by: com.sshtools.j2ssh.transport.TransportProtocolException: The connection did not complete
来自j2ssh的调试日志显示以下内容:
com.sshtools.j2ssh.transport.TransportProtocolCommon.beginKeyExchange(Unknown Source) | Starting key exchange
com.sshtools.j2ssh.transport.TransportProtocolCommon.determineAlgorithm(Unknown Source) | Determine Algorithm
com.sshtools.j2ssh.transport.TransportProtocolCommon.determineAlgorithm(Unknown Source) | Client Algorithms: [diffie-hellman-group1-sha1]
com.sshtools.j2ssh.transport.TransportProtocolCommon.determineAlgorithm(Unknown Source) | Server Algorithms: [diffie-hellman-group14-sha1, diffie-hellman-group-exchange-sha1]
com.sshtools.j2ssh.transport.TransportProtocolCommon.sendMessage(Unknown Source) | Sending SSH_MSG_DISCONNECT
com.sshtools.j2ssh.transport.TransportProtocolCommon.run(Unknown Source) | The Transport Protocol has been stopped
从上面可以看到,在我的应用程序和服务器之间没有用于密钥交换的匹配算法(调试实际上表明,当没有服务器和客户端算法匹配时,此问题的根源是
AlgorithmNotAgreedException
,所以我知道这是根本原因)。如何向j2ssh添加新算法,以便它可以找到匹配项? j2ssh文档非常稀疏。
最佳答案
j2ssh发行版中应该有一个sshtools.xml文件。在该文件中,您可以添加其他ExtensionAlgorithm条目以进行映射
diffie-hellman-group14-sha1 to
com.maverick.ssh.components.jce.DiffieHellmanGroup14Sha1
或者
com.maverick.ssh.components.standalone.DiffieHellmanGroup14Sha1
关于java - J2SSH-添加 key 交换算法,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/10323092/