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

2025-05-29 0 70

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

介绍

AESDES同属对称加密算法,数据发信方将明文(原始数据)和加密密钥一起经过特殊加密算法处理后,使其变成复杂的加密密文发送出去。收信方收到密文后,若想解读原文,则需要使用加密用过的密钥及相同算法的逆算法对密文进行解密,才能使其恢复成可读明文。在对称加密算法中,使用的密钥只有一个,发收信双方都使用这个密钥对数据进行加密解密,这就要求解密方事先必须知道加密密钥。

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

引入Hutool

?

1

2

3

4

5
<dependency>

<groupId>com.xiaoleilu</groupId>

<artifactId>hutool-all</artifactId>

<version>3.0.9</version>

</dependency>

使用

AES加密解密

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17
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基本一致

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15
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类,AESDES两个类是此类的简化表示。通过实例化这个类传入相应的算法枚举即可使用相同方法加密解密字符串或对象。

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

  1. AES
  2. ARCFOUR
  3. Blowfish
  4. DES
  5. DESede
  6. RC2
  7. PBEWithMD5AndDES
  8. PBEWithSHA1AndDESede
  9. PBEWithSHA1AndRC2_40

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

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

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17
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);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。

原文链接:https://my.oschina.net/looly/blog/1504160

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 Java使用Hutool实现AES、DES加密解密的方法 https://www.kuaiidc.com/115435.html

相关文章

发表评论
暂无评论