Java使用Hutool實(shí)現(xiàn)AES、DES加密解密的方法
在Java世界中,AES、DES加密解密需要使用Cipher對(duì)象構(gòu)建加密解密系統(tǒng),Hutool中對(duì)這一對(duì)象做再包裝,簡(jiǎn)化了加密解密過程。
介紹
AES和DES同屬對(duì)稱加密算法,數(shù)據(jù)發(fā)信方將明文(原始數(shù)據(jù))和加密密鑰一起經(jīng)過特殊加密算法處理后,使其變成復(fù)雜的加密密文發(fā)送出去。收信方收到密文后,若想解讀原文,則需要使用加密用過的密鑰及相同算法的逆算法對(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)化了加密解密過程。
引入Hutool
<dependency> <groupId>com.xiaoleilu</groupId> <artifactId>hutool-all</artifactId> <version>3.0.9</version> </dependency>
使用
AES加密解密
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基本一致
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)化表示。通過實(shí)例化這個(gè)類傳入相應(yīng)的算法枚舉即可使用相同方法加密解密字符串或?qū)ο蟆?/p>
Hutool支持的對(duì)稱加密算法枚舉有:
- AES
- ARCFOUR
- Blowfish
- DES
- DESede
- RC2
- PBEWithMD5AndDES
- PBEWithSHA1AndDESede
- PBEWithSHA1AndRC2_40
這些枚舉全部在SymmetricAlgorithm中被列舉
對(duì)稱加密對(duì)象的使用也非常簡(jiǎn)單:
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í)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
導(dǎo)入renren-fast出現(xiàn)問題以及解決方案
文章介紹了在導(dǎo)入renren-fast項(xiàng)目時(shí)遇到的maven繼承parent問題,并提供了解決方案,即在pom文件中添加``標(biāo)簽,此外,還詳細(xì)解釋了Maven的``標(biāo)簽的作用以及MAVEN構(gòu)建jar包時(shí)的查找順序2024-11-11Java字符編碼簡(jiǎn)介_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了Java字符編碼簡(jiǎn)介,本文主要包括以下幾個(gè)方面:編碼基本知識(shí),Java,系統(tǒng)軟件,url,工具軟件等,感興趣的朋友一起看看吧2017-08-08Spring AOP的幾種實(shí)現(xiàn)方式總結(jié)
本篇文章主要介紹了Spring AOP的幾種實(shí)現(xiàn)方式總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02