当前位置: 首页 > news >正文

解决java客户端连接ssh失败问题

的运维工具使用了java的ssh客户端,这些客户端和服务端间有时会出现加密算法协商失败和主机密钥类型协商失败的问题,该问题是由于新客户端/服务端禁用了相关的不安全算法和密钥类型,本文简要记录下该问题的解决方法以备不时之需。

错误常见提示如下:

#加密算法协商失败
Unable to negotiate with 192.168.56.99 port 54234: no matching key exchange method found. Their offer: diffie-hellman-group-exchange-sha1,diffie-hellman-group14-sha1,diffie-hellman-group1-sha1 [preauth]
#主机密钥类型协商失败
Unable to negotiate with 192.168.56.99 port 22: no matching host key type found. Their offer: ssh-rsa,ssh-dss [preauth]

解决方法

二选一:

较新的客户端兼容旧服务端

以Jsch为例,升级新版本。

<dependency>
<groupId>com.jcraft</groupId>
<artifactId>jsch</artifactId>
<version>0.1.55</version> <!-- 检查最新版本 -->
</dependency>

代码中配置连接属性:

import com.jcraft.jsch.*;
public class SSHConnector {
public static void main(String[] args) {
try {
JSch jsch = new JSch();
// 设置支持的算法
java.util.Properties config = new java.util.Properties();
// 关键配置:指定算法
config.put("kex", "diffie-hellman-group1-sha1,diffie-hellman-group14-sha1");
config.put("server_host_key", "ssh-rsa,ssh-dss");
config.put("cipher.s2c", "aes128-ctr,aes128-cbc,3des-cbc");
config.put("cipher.c2s", "aes128-ctr,aes128-cbc,3des-cbc");
config.put("mac.s2c", "hmac-sha1");
config.put("mac.c2s", "hmac-sha1");
Session session = jsch.getSession("username", "172.16.29.254", 22);
session.setConfig(config);
session.setPassword("password");
session.setConfig("StrictHostKeyChecking", "no"); // 临时测试用
session.connect(30000); // 30秒超时
System.out.println("连接成功");
session.disconnect();
} catch (JSchException e) {
e.printStackTrace();
}
}
}

较新的服务端兼容旧客户端

/etc/ssh/sshd_config追加以下内容,这里添加的算法取决于Their offer后边提示的类型,一般只添加部分即可,推荐使用+追加额外算法。

#解决no matching key exchange method found报错
KexAlgorithms +diffie-hellman-group14-sha1
#解决no matching host key type found报错
HostKeyAlgorithms +ssh-rsa

附查看服务端ssh支持算法

hellxz@hz:~$ sudo sshd -T | grep -E "^hostkeyalg|^kexalg"
kexalgorithms sntrup761x25519-sha512@openssh.com,curve25519-sha256,curve25519-sha256@libssh.org,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,diffie-hellman-group-exchange-sha256,diffie-hellman-group16-sha512,diffie-hellman-group18-sha512,diffie-hellman-group14-sha256,diffie-hellman-group14-sha1
hostkeyalgorithms ssh-ed25519-cert-v01@openssh.com,ecdsa-sha2-nistp256-cert
http://www.jsqmd.com/news/487078/

相关文章:

  • 腾讯对OpenClaw技能数据的抓取行为,究竟是符合开源精神的本地镜像还是侵害开发者权益的恶意抄袭?
  • 污水厂高清效果图,3D渲染后高清图 基本污水厂的工艺段该有的都有, 可以直接应用 50多套工艺...
  • LangChain/LangGraph/OpenAI核心概念+实战指南
  • JDK编译版本的错误
  • 搞微电网仿真就像搭乐高,只不过每个模块都得带脑子。今天咱们聊聊风光储氢全家桶怎么玩并离网切换和调频,直接上干货
  • 宁夏鑫玖恒钢结构丨设计、生产、销售、施工一体化综合服务商 - 宁夏壹山网络
  • 计及绿证交易与碳排放的智能楼宇微网优化调度模型-原创系列
  • 各子群独立进化
  • YOLO11 改进 - SPPF模块 _ SPPELAN 空间金字塔池化与增强局部注意力:替代SPPF增强多尺度上下文捕获,提升检测精度
  • 基于核主成分分析的回归数据降维可视化方法及Matlab实现
  • C语言基础学完后底层开发卡壳?这三个开源项目帮你破局
  • 华为OD机考双机位C卷 - 模拟消息队列 (Java Python JS GO C++ C)
  • VAE变分自编码器VAE Loss基础数学知识
  • JavaWeb SpringBoot 总结
  • YOLO26改进97:全网首发--c3k2模块添加GCConv模块:垂直多卷积与水平多路径结构进行训练
  • openclaw 运维及使用
  • 互斥信号量和二值信号量的区别
  • 维科技术2025年亏损收窄至1.02亿!钠电池爬坡期后的业绩拐点已现?
  • 2026年降AI率工具哪个好?亲测这3款真的有效
  • 原来那些 TikTok 百万播放的带货视频,是在 Clipcat 一键复刻的?10 分钟爆单
  • 毕业论文AI率超标怎么办?这几款降AI工具帮你轻松过关
  • iNaturalist开放海量自然数据与计算机视觉挑战
  • 卷积神经网络零基础-Alexnet网络
  • D3DCompiler_47.dll怎么解决?当运行某程序出现提示找不到此文件问题
  • 如何通过485通信控制汇川电机
  • 锂离子电池的充电状态和健康状态估计 石墨-磷酸铁锂电池的循环寿命模型 该项目的目标是设计一个强...
  • 光储直流微电网Simulink仿真模型——独立光伏系统能量管理及最大功率点跟踪
  • 2026最新!AI大模型系统学习路线图曝光,从入门到商业落地_AI大模型的详细完整学习路线,从入门到精通
  • 打开软件时弹出提示D3DCompiler_47.dll文件找不到无法启动应用解决方法
  • 文档检索软件self searcher绿色版下载