Jsch报无效算法参数异常错误处理
1、问题描述:
Java连接sftp,通过jsch jar包进行连接,目前java版本1.7会报如下错误:
2018-07-19 20:35:10,700 INFO SFTPUtils: Session created.
com.jcraft.jsch.JSchException: Session.connect: java.security.InvalidAlgorithmParameterException: Prime size must be multiple of 64, and can only range from 512 to 1024 (inclusive)
at com.jcraft.jsch.Session.connect(Session.java:557)
at com.jcraft.jsch.Session.connect(Session.java:183)
at com.zznode.nwtl.tp.dataprocess.util.SFTPUtils.connect(SFTPUtils.java:76)
at com.zznode.nwtl.pm.sqm.SqmPmDataProcess.probeSqmFile(SqmPmDataProcess.java:382)
at com.zznode.nwtl.pm.sqm.SqmPmDataProcess.main(SqmPmDataProcess.java:84)
2018-07-19 20:35:11,098 INFO SqmPmDataProcess: 6666
2018-07-19 20:35:11,099 ERROR SqmPmDataProcess: java.lang.NullPointerException
at com.zznode.nwtl.tp.dataprocess.util.SFTPUtils.listFiles(SFTPUtils.java:494)
at com.zznode.nwtl.tp.dataprocess.util.SFTPUtils.batchDownLoadFile(SFTPUtils.java:143)
at com.zznode.nwtl.pm.sqm.SqmPmDataProcess.probeSqmFile(SqmPmDataProcess.java:385)
at com.zznode.nwtl.pm.sqm.SqmPmDataProcess.main(SqmPmDataProcess.java:84)
VMW000000545:/home/nwtl/NWTL_HOME/tpdataprocess/bin$
2、问题说明:
这个错误是由于JVM不允许安全**长度大于1024字节导致,需要修改安全策略。
3、解决方案:
1、下载bcprov-jdk包:
下载地址:https://www.bouncycastle.org/latest_releases.html
下载以下截图中的2个jar包
2、上传jar包:
上传至$JAVA_HOME/jre/lib/ext目录。
3、修改java.security文件:
$JAVA_HOME/jre/lib/security/java.security
cp java.security java.security_lfd_20180719
vi java.security
将security.provider.2=sun.security.rsa.SunRsaSign修改为:
security.provider.2=org.bouncycastle.jce.provider.BouncyCastleProvider
然后重启应用,则不再报错。
参考链接:
最近碰到一些sftp的问题,比如
jsch_0.1.53.jar + jdk1.6报异常:com.jcraft.jsch.JSchException: Session.connect: java.io.IOException: End of IO Stream Read
翻遍了网上的解决方案都没有用,最终还是用bouncycastle加密包解决问题!!!
这个异常和上面的异常,都是同一类问题。
本文解决方案提供者:刘方丹,分享此文 ,希望对所有遇到此问题的开发者有所帮助。