用jsch.jar session.connect() 登录sftp服务器上报错 :End of IO Stream Read

原创
2017/06/29 15:07
阅读数 2.9W

1.概述

    最近做了一个从sftp服务器上下载文件的java项目。用到了jsch-0.1.54.jar

2.过程

    本机搭建了一个sftp服务器环境测试没问题。centos6.8+ssh opensever

    代码打到客户测试环境,运行报错:

com.jcraft.jsch.JSchException: Session.connect: java.io.IOException: End of IO Stream Read

3.解决

1)经过多次测试,排查问题。推测是环境ssh版本问题,由于客户环境不可见,无法获得sftp服务器ssh的版本。

2)上网搜寻这个错误,发现国内遇到这个问题不多。国外stackoverflow网站上有贴出一样的报错,但是引用的jar版本不同,并且答案指出升级到jsch-0.1.54问题就不存在了。

    继续百度,寻找关键字信息,逐渐追到jsch的源码里面,IO异常显示是keyexchange(ssh DH私钥交换)读取有误(文件读取流到底)。

3)小心测试,解决问题。

在sftp登录时,设置完ip,port,user和pwd之后

再设置传输的DH私钥内容:

session.setConfig("kex",“diffie-hellman-group1-sha1”);

相关内容地址:

http://blog.csdn.net/wchrt/article/details/45752933

展开阅读全文
打赏
0
1 收藏
分享
加载中
更多评论
打赏
0 评论
1 收藏
0
分享
返回顶部
顶部