在Java世界中,AES、DES加密解密需要使用Cipher對(duì)象構(gòu)建加密解密系統(tǒng),Hutool中對(duì)這一對(duì)象做再包裝,簡(jiǎn)化了加密解密過(guò)程。
介紹
AES和DES同屬對(duì)稱加密算法,數(shù)據(jù)發(fā)信方將明文(原始數(shù)據(jù))和加密密鑰一起經(jīng)過(guò)特殊加密算法處理后,使其變成復(fù)雜的加密密文發(fā)送出去。收信方收到密文后,若想解讀原文,則需要使用加密用過(guò)的密鑰及相同算法的逆算法對(duì)密文進(jìn)行解密,才能使其恢復(fù)成可讀明文。在對(duì)稱加密算法中,使用的密鑰只有一個(gè),發(fā)收信雙方都使用這個(gè)密鑰對(duì)數(shù)據(jù)進(jìn)行加密和解密,這就要求解密方事先必須知道加密密鑰。
在Java世界中,AES、DES加密解密需要使用Cipher對(duì)象構(gòu)建加密解密系統(tǒng),Hutool中對(duì)這一對(duì)象做再包裝,簡(jiǎn)化了加密解密過(guò)程。
引入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中文" ; //隨機(jī)生成密鑰 byte [] key = SecureUtil.generateKey(SymmetricAlgorithm.AES.getValue()).getEncoded(); //構(gòu)建 AES aes = SecureUtil.aes(key); //加密 byte [] encrypt = aes.encrypt(content); //解密 byte [] decrypt = aes.decrypt(encrypt); //加密為16進(jìn)制表示 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中文" ; //隨機(jī)生成密鑰 byte [] key = SecureUtil.generateKey(SymmetricAlgorithm.DES.getValue()).getEncoded(); //構(gòu)建 DES des = SecureUtil.des(key); //加密解密 byte [] encrypt = des.encrypt(content); byte [] decrypt = des.decrypt(encrypt); //加密為16進(jìn)制,解密為原字符串 String encryptHex = des.encryptHex(content); String decryptStr = des.decryptStr(encryptHex); |
更多
Hutool中針對(duì)JDK支持的所有對(duì)稱加密算法做了封裝,封裝為SymmetricCrypto類,AES和DES兩個(gè)類是此類的簡(jiǎn)化表示。通過(guò)實(shí)例化這個(gè)類傳入相應(yīng)的算法枚舉即可使用相同方法加密解密字符串或?qū)ο蟆?/p>
Hutool支持的對(duì)稱加密算法枚舉有:
- AES
- ARCFOUR
- Blowfish
- DES
- DESede
- RC2
- PBEWithMD5AndDES
- PBEWithSHA1AndDESede
- PBEWithSHA1AndRC2_40
這些枚舉全部在SymmetricAlgorithm中被列舉
對(duì)稱加密對(duì)象的使用也非常簡(jiǎn)單:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
String content = "test中文" ; //隨機(jī)生成密鑰 byte [] key = SecureUtil.generateKey(SymmetricAlgorithm.AES.getValue()).getEncoded(); //構(gòu)建 SymmetricCrypto aes = new SymmetricCrypto(SymmetricAlgorithm.AES, key); //加密 byte [] encrypt = aes.encrypt(content); //解密 byte [] decrypt = aes.decrypt(encrypt); //加密為16進(jìn)制表示 String encryptHex = aes.encryptHex(content); //解密為字符串 String decryptStr = aes.decryptStr(encryptHex); |
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://my.oschina.net/looly/blog/1504160