windows上加解密正常,linux上加密正常,解密时发生 如下异常,异常信息如下:[ERROR] 2018-10-15 09:30:35,998 method:com.iscas.ippc.common.utils.RandomPwd.decrypt(RandomPwd.java:120)decrypt Exception is G...
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());
本文标题为:JAVA的DES加密解密在windows上测试一切正常,在linux上异常
基础教程推荐
- 关于Java双大括号{{}}的具体使用 2023-03-15
- Java多线程学习笔记之三内存屏障与Java内存模型 2023-09-01
- Spring Cloud Config分布式配置中心使用介绍详解 2023-05-07
- java知识点7——面向过程和面向对象、面向对象的内存分析、构造方法 2023-09-01
- Java实现插入排序算法可视化的示例代码 2023-04-23
- Java List的get方法 2023-10-08
- Java Web开发中过滤器和监听器使用详解 2023-06-30
- MyBatis-Plus自定义通用的方法实现 2023-07-15
- 一文带你搞懂Java中方法重写与方法重载的区别 2023-07-14
- RocketMQ Push 消费模型示例详解 2023-05-24
