開箱即用的AES CBC加密解密算法分享
這兩個(gè)天一個(gè)朋友讓幫忙有java封裝一個(gè)AES CBC算法的加解密仙蚜,果斷的Ctrl+C
和Ctrl+V
椭微。修修改改形成了一下代碼。至于什么是AES CBC模式加密算法,我也不知道(猛男落淚~~)。網(wǎng)上一搜一大堆這些資料感興趣的可以百度贴彼。
Java自帶沒有AES加密算法的jar包,需要手動(dòng)添加埃儿,此處使用maven自動(dòng)下載:
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk16</artifactId>
<version>1.46</version>
</dependency>
接下來就是正文了:
package cn.diaoyc.aes;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
/**
* @author Tony
* @projectName AESCB
* @title AecCBCUtil
* @package cn.diaoyc.aes
* @date 2020/5/10 -- 10:06
* @version v1.1
*
*/
public class AecCBCUtil {
// 加密方式
private static String ALGORITHM = "AES";
//算法數(shù)據(jù)填充方式
private static String ALGORITHM_FILL_TYPE = "AES/CBC/PKCS5Padding";
//字符編碼(String轉(zhuǎn)byte[] 使用UTF-8的編碼格式)
private static String ENCODING_FORMAT = "UTF-8";
// 內(nèi)部實(shí)例參數(shù)
private static AecCBCUtil instance = null;
private AecCBCUtil() {
}
//采用單例模式,此靜態(tài)方法供外部直接訪問
public static AecCBCUtil getInstance() {
if (instance == null) {
instance = new AecCBCUtil();
}
return instance;
}
/**
* 加密
* @param originalContent 明文
* @param encryptKey 密鑰
* @param ivParameter 初始偏移量
* @return 返回加密后的字符串
*/
public String encrypt(String originalContent, String encryptKey, String ivParameter) {
try {
//處理傳進(jìn)來的明文
byte[] originalContentBytes = originalContent.getBytes(ENCODING_FORMAT);
//處理傳進(jìn)來的密鑰(String轉(zhuǎn)成byte[])
byte[] enKeyBytes = encryptKey.getBytes();
//處理傳進(jìn)來的偏移量(String轉(zhuǎn)成byte[])
byte[] ivParameterBytes = ivParameter.getBytes();
//根據(jù)傳入的密鑰按照AEC方式構(gòu)造密鑰
SecretKeySpec sKeySpec = new SecretKeySpec(enKeyBytes, ALGORITHM);
//根據(jù)傳入的偏移量指定一個(gè)初始化偏移量
IvParameterSpec iv = new IvParameterSpec(ivParameterBytes);
//根據(jù)數(shù)據(jù)填充方式生成一個(gè)加解密對(duì)象
Cipher cipher = Cipher.getInstance(ALGORITHM_FILL_TYPE);
//初始化 傳入類型(加密/解密)融涣、構(gòu)造過的密鑰童番、指定的初始偏移量
cipher.init(Cipher.ENCRYPT_MODE, sKeySpec, iv);
//加密操作
byte[] encrypted = cipher.doFinal(originalContentBytes);
//base64轉(zhuǎn)碼
String cipherString = new BASE64Encoder().encode(encrypted);
return cipherString;
} catch (Exception e) {
throw new RuntimeException(e);
}
}
/**
* 解密
* @param cipherStr 加密過的密文
* @param encryptKey 密鑰
* @param ivParameter 偏移量
* @return 返回解密過后的字符串
*/
public String decrypt(String cipherStr, String encryptKey, String ivParameter) {
try {
//處理傳進(jìn)來的密文 使用base64解密
byte[] cipherStrByte = new BASE64Decoder().decodeBuffer(cipherStr);
//處理傳進(jìn)來的密鑰(String轉(zhuǎn)成byte[]) 可以指定編碼格式為:ASCII
byte[] enKeyBytes = encryptKey.getBytes();
//處理傳進(jìn)來的偏移量(String轉(zhuǎn)成byte[])
byte[] ivParameterBytes = ivParameter.getBytes();
//根據(jù)傳入的密鑰按照AEC方式構(gòu)造密鑰
SecretKeySpec sKeySpec = new SecretKeySpec(enKeyBytes, ALGORITHM);
Cipher cipher = Cipher.getInstance(ALGORITHM_FILL_TYPE);
IvParameterSpec iv = new IvParameterSpec(ivParameterBytes);
cipher.init(Cipher.DECRYPT_MODE, sKeySpec, iv);
//獲得解密的明文數(shù)組
byte[] original = cipher.doFinal(cipherStrByte);
return new String(original, ENCODING_FORMAT);
} catch (Exception e) {
throw new RuntimeException(e);
}
}
public static void main(String[] args) {
String originalContent = "{\"fsadfds\":{\"fdsfsdf\":\"sdfdfds\",\"sfdsfsd\":{\"sfdsfd\":\"\",\"sfsdfsdf\":\"\",\"sfdsfdsf\":\"\",\"sfsfsdf\":\"\"},\"sfsfs\":\"sfsfsf\",\"Type\":1,\"sfsfsf\":\"sfsfsfsdfsdfdfsdfs\"},\"P\":\"sfsfsf-sfdsfsdf-123456\",\"U\":\"fsdfdfds-sfsdf\"}";
String encryptKey = "N200fqw455uEghx5"; //密鑰
String ivParameter = "Ipahgj7Jkl0Gwe7s";//偏移量
System.out.println("原始字符串:" + originalContent);
//加密
String encrypt = AecCBCUtil.getInstance().encrypt(originalContent, encryptKey, ivParameter);
System.out.println("加密后的字符串是:" + encrypt);
System.out.println("****************我是分割線*******************");
//解密
String decrypt = AecCBCUtil.getInstance().decrypt(encrypt, encryptKey, ivParameter);
System.out.println("解密后的:" + decrypt);
}
}