1. 程式人生 > >Java使用Hutool實現AES、DES加密解密

Java使用Hutool實現AES、DES加密解密

介紹

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類,AESDES兩個類是此類的簡化表示。通過例項化這個類傳入相應的演算法列舉即可使用相同方法加密解密字串或物件。

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);