问题描述:
项目中要用到和SFTP进行连接上传文件,用户名密码IP什么的要配置在WAS服务器里面,出于安全性考虑,需要把这些连接的必要信息用AES-256进行加密,加密自己写了一个桌面工具,把加密过后的信息放到WAS配置文件里面,但是问题来了,在应用程序运行过程中,并没有成功的解密,报错如下:
javax.crypto.BadPaddingException:Given final block not properly padded

问题原因:
由于我桌面工具运行的时候是依赖的我本机的SUN的JDK, 他的JCE提供程序是SunJCE, 在WAS运行环境下,JDK是IBM提供的,JCE提供程序是IBMJCE, 两边的实现有差异,所以用SunJCE加密的东西再用IBEJCE解密就报错了。
解决办法:
我把WAS的runtime环境拷贝出来了,放在我桌面工具的目录下面,运行工具的时候,直接指定我的运行环境从IBM的JVM运行,这样就保证了加密过程也是通过IBMJCE走的。

start.bat 内容:
path = jre\bin;
java -cp lib\ur_jar_name.jar; theEntryMainClass

本文介绍了一种使用AES-256加密SFTP连接信息的方法,解决了因JCE提供程序不同导致的加密解密不一致的问题。通过指定统一的JCE提供者实现了跨平台的加密解密。
2426

被折叠的 条评论
为什么被折叠?



