Quantcast
Channel: CodeSection,代码区,网络安全 - CodeSec
Viewing all articles
Browse latest Browse all 12749

每日一博 | Java 使用 Hutool 实现 AES、DES 加密解密

0
0
介绍

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

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

引入Hutool <dependency> <groupId>com.xiaoleilu</groupId> <artifactId>hutool-all</artifactId> <version>3.0.9</version> </dependency> 使用 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);

Viewing all articles
Browse latest Browse all 12749