AES和DES同屬對稱加密算法,數據發信方將明文(原始數據)和加密密鑰一塊兒通過特殊加密算法處理後,使其變成複雜的加密密文發送出去。收信方收到密文後,若想解讀原文,則須要使用加密用過的密鑰及相同算法的逆算法對密文進行解密,才能使其恢復成可讀明文。在對稱加密算法中,使用的密鑰只有一個,發收信雙方都使用這個密鑰對數據進行加密和解密,這就要求解密方事先必須知道加密密鑰。java
在Java世界中,AES、DES加密解密須要使用Cipher對象構建加密解密系統,Hutool中對這一對象作再包裝,簡化了加密解密過程。算法
<dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>4.1.2</version> </dependency>
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 = aes.encryptHex(content); //解密爲原字符串 String decryptStr = aes.decryptStr(encryptHex);
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
兩個類是此類的簡化表示。經過實例化這個類傳入相應的算法枚舉便可使用相同方法加密解密字符串或對象。code
Hutool支持的對稱加密算法枚舉有:xml
這些枚舉所有在SymmetricAlgorithm
中被列舉對象
對稱加密對象的使用也很是簡單:ip
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);