JAVA的DES加密解密在windows上测试一切正常,在linux上异常

windows上加解密正常,linux上加密正常,解密时发生 如下异常,异常信息如下:

[ERROR] 2018-10-15 09:30:35,998 method:com.iscas.ippc.common.utils.RandomPwd.decrypt(RandomPwd.java:120)
decrypt Exception is Given final block not properly padded. Such issues can arise if a bad key is used during decryption.
javax.crypto.BadPaddingException: Given final block not properly padded. Such issues can arise if a bad key is used during decryption.
at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:991)
at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:847)
at com.sun.crypto.provider.DESCipher.engineDoFinal(DESCipher.java:314)
at javax.crypto.Cipher.doFinal(Cipher.java:2164)

 

Des修改方式如下

private static SecretKeySpec getSecretKey() {
//返回生成指定算法密钥生成器的 KeyGenerator 对象
KeyGenerator kg = null;

try {
kg = KeyGenerator.getInstance(KEY_ALGORITHM);

//DES 要求密钥长度为 256
SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
random.setSeed(KEY_STRING.getBytes());
kg.init(56,random);

//生成一个密钥
SecretKey secretKey = kg.generateKey();

return new SecretKeySpec(secretKey.getEncoded(), KEY_ALGORITHM);// 转换为DES专用密钥

} catch (NoSuchAlgorithmException e) {
logger.error("getSecretKey Exception is "+e.getMessage(),e);
}

return null;
}

主要是SecureRandom 红色部分的问题,

修改前:

kg.init(56,new SecureRandom(key.getBytes()));

修改成下面的代码即可:

SecureRandom random = SecureRandom.getInstance("SHA1PRNG");
random.setSeed(KEY_STRING.getBytes());

 

 

转载于:https://www.cnblogs.com/beautifulFuture/p/9789591.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值