Java項(xiàng)目中AES與DES的加密解密怎么利用Hutool實(shí)現(xiàn)?相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。
目前成都創(chuàng)新互聯(lián)已為上千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)站空間、網(wǎng)站改版維護(hù)、企業(yè)網(wǎng)站設(shè)計(jì)、康平網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。
介紹
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
com.xiaoleilu hutool-all 3.0.9
使用
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)化表示。通過(guò)實(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);
看完上述內(nèi)容,你們掌握J(rèn)ava項(xiàng)目中AES與DES的加密解密怎么利用Hutool實(shí)現(xiàn)的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!