Hutool进行DES加解密
先简述以下:一个数据接口,接收到的是DES加密后的json字符串,需要先解密再转成bean对象。
我试了网上很多方式实现,发现每次加密后最后几位不同。想着对称加解密还能这样?(因为绝大多数示例都是main方法测试)
最后发现是如果你的密钥不够24位会自动随机补足,密钥发生变化。
每次重启项目密钥都不同,因此报解密到最后一块有异常。
在web项目中使用可以将24位的密钥明文存储到数据库或配置文件中。
依赖,hutool版本能用就行
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.8.0.M2</version>
</dependency>
加解密工具类(简单封装)
import cn.hutool.crypto.symmetric.SymmetricAlgorithm;
import cn.hutool.crypto.symmetric.SymmetricCrypto;
public class DESUtil {
private static final SymmetricCrypto des;
static {
// sgEsnN6QWq8W7j5H01020304即为密钥明文长24位,
// 不够则会随机补足24位
des = new SymmetricCrypto(SymmetricAlgorithm.DES, "sgEsnN6QWq8W7j5H01020304".getBytes());
}
/**
* des解密
* @param content 密文
* @return 解密后的明文
*/
public static String decrypt(String content) {
return des.decryptStr(content);
}
/**
* des加密
* @param content 明文
* @return 加密后的密文
*/
public static String encryption(String content) {
return des.encryptHex(content);
}
}
在接口里直接调用静态方法即可。就不测试了,这种工具类不会出问题。
需要注意的是像上面的工具类,被解密的密文也必须是用"sgEsnN6QWq8W7j5H01020304"作为密钥加密的,否则解密会报错。