Java使用Hutool实现AES、DES加密解密的方法

网友投稿 577 2023-04-22


Java使用Hutool实现AES、DES加密解密的方法

在java世界中,AES、DES加密解密需要使用Cipher对象构建加密解密系统,Hutool中对这一对象做再包装,简化了加密解密过程。

介绍

在Java世界中,AES、DES加密解密需要使用Cipher对象构建加密解密系统,Hutool中对这一对象做再包装,简化了加密解密过程。

引入Hutool

com.xiaoleilu

hutool-all

3.0.9

使用

AES加密解密

String content = "test中文";

//随机生成密钥

byte[] key = SecureUtil.generateKey(SymmetricAlgorithm.AES.getValue()).getEncoded();

//构建

AES aes = SecureUtil.aes(key);

//加密

byte[] encrypt = aes.encrypt(content);

//解密

byte[] decrypt = aes.decrypt(encrypt);

//加密为16进制表示

String encryptHex = des.encryptHex(content);

//解密为原字符串

String decryptStr = des.decryptStr(encryptHex);

DES加密解密

DES的使用方式与AES基本一致

String content = "test中文";

//随机生成密钥

byte[] key = SecureUtil.generateKey(SymmetricAlgorithm.DES.getValue()).getEncoded();

//构建

DES des = SecureUtil.des(key);

//加密解密

byte[] encrypt = des.encrypt(content);

byte[] decrypt = des.decrypt(encrypt);

//加密为16进制,解密为原字符串

String encryptHex = des.encryptHex(content);

String decryptStr = des.decryptStr(encryptHex);

更多

Hutool中针对JDK支持的所有对称加密算法做了封装,封装为SymmetricCrypto类,AES和DES两个类是此类的简化表示。通过实例化这个类传入相应的算法枚举即可使用相同方法加密解密字符串或对象。

Hutool支持的对称加密算法枚举有:

AES

ARCFOUR

Blowfish

DES

DESede

RC2

PBEWithMD5AndDES

PBEWithSHA1AndDESede

PBEWithSHA1AndRC2_40

这些枚举全部在SymmetricAlgorithm中被列举

对称加密对象的使用也非常简单:

String content = "test中文";

//随机生成密钥

byte[] key = SecureUtil.generateKey(SymmetricAlgorithm.AES.getValue()).getEncoded();

//构建

SymmetricCrypto aes = new SymmetricCrypto(SymmetricAlgorithm.AES, key);

//加密

byte[] encrypt = aes.encrypt(content);

//解密

byte[] decrypt = aes.decrypt(encrypt);

//加密为16进制表示

String encryptHex = aes.encryptHex(content);

//解密为字符串

String decryptStr = aes.decryptStr(encryptHex);


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:angular+ionic返回上一页并刷新页面
下一篇:微信小程序movable view移动图片和双指缩放实例代码
相关文章

 发表评论

暂时没有评论,来抢沙发吧~