81 lines
2.4 KiB
Java
81 lines
2.4 KiB
Java
|
|
package com.mini.capi.utils;
|
|||
|
|
|
|||
|
|
import javax.crypto.Cipher;
|
|||
|
|
import javax.crypto.spec.IvParameterSpec;
|
|||
|
|
import javax.crypto.spec.SecretKeySpec;
|
|||
|
|
|
|||
|
|
import org.apache.commons.net.util.Base64;
|
|||
|
|
|
|||
|
|
public class AESUtil {
|
|||
|
|
public static String key = "AD42F6697B035B7580E4FEF93BE20BAD";
|
|||
|
|
private static String charset = "utf-8";
|
|||
|
|
// 偏移量
|
|||
|
|
private static int offset = 16;
|
|||
|
|
private static String transformation = "AES/CBC/PKCS5Padding";
|
|||
|
|
private static String algorithm = "AES";
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* 加密
|
|||
|
|
*
|
|||
|
|
* @param content
|
|||
|
|
* @return
|
|||
|
|
*/
|
|||
|
|
public static String encrypt(String content) {
|
|||
|
|
return encrypt(content, key);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* 解密
|
|||
|
|
*
|
|||
|
|
* @param content
|
|||
|
|
* @return
|
|||
|
|
*/
|
|||
|
|
public static String decrypt(String content) {
|
|||
|
|
return decrypt(content, key);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* 加密
|
|||
|
|
*
|
|||
|
|
* @param content 需要加密的内容
|
|||
|
|
* @param key 加密密码
|
|||
|
|
* @return
|
|||
|
|
*/
|
|||
|
|
public static String encrypt(String content, String key) {
|
|||
|
|
try {
|
|||
|
|
SecretKeySpec skey = new SecretKeySpec(key.getBytes(), algorithm);
|
|||
|
|
IvParameterSpec iv = new IvParameterSpec(key.getBytes(), 0, offset);
|
|||
|
|
Cipher cipher = Cipher.getInstance(transformation);
|
|||
|
|
byte[] byteContent = content.getBytes(charset);
|
|||
|
|
cipher.init(Cipher.ENCRYPT_MODE, skey, iv);// 初始化
|
|||
|
|
byte[] result = cipher.doFinal(byteContent);
|
|||
|
|
return new Base64().encodeToString(result).replaceAll("[\\s*\t\n\r]", ""); // 加密
|
|||
|
|
} catch (Exception e) {
|
|||
|
|
System.out.println(e.getMessage());
|
|||
|
|
}
|
|||
|
|
return null;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* AES(256)解密
|
|||
|
|
*
|
|||
|
|
* @param content 待解密内容
|
|||
|
|
* @param key 解密密钥
|
|||
|
|
* @return 解密之后
|
|||
|
|
* @throws Exception
|
|||
|
|
*/
|
|||
|
|
public static String decrypt(String content, String key) {
|
|||
|
|
try {
|
|||
|
|
SecretKeySpec skey = new SecretKeySpec(key.getBytes(), algorithm);
|
|||
|
|
IvParameterSpec iv = new IvParameterSpec(key.getBytes(charset), 0, offset);
|
|||
|
|
Cipher cipher = Cipher.getInstance(transformation);
|
|||
|
|
cipher.init(Cipher.DECRYPT_MODE, skey, iv);// 初始化
|
|||
|
|
byte[] result = cipher.doFinal(new Base64().decode(content));
|
|||
|
|
return new String(result).replaceAll("[\\s*\t\n\r]", ""); // 解密
|
|||
|
|
} catch (Exception e) {
|
|||
|
|
System.out.println(e.getMessage());
|
|||
|
|
}
|
|||
|
|
return null;
|
|||
|
|
}
|
|||
|
|
}
|