package com.hollysys.smartfactory.equipmentdiagnosis.util; import lombok.extern.log4j.Log4j2; import org.apache.commons.codec.binary.Base64; import javax.crypto.Cipher; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; /** * Description: 对称加密 * * @author cy * @date 2019年08月05日 14:18 * Version 1.0 */ @Log4j2 public class AesUtil { /** * 密钥 */ private static String key = "AD42F6697B045B7580E4FEF93BE80BRG"; private static String charset = "utf-8"; /** * 偏移量 */ private static int offset = 16; /** * 加密器类型:加密算法为AES,加密模式为CBC,补码方式为PKCS5Padding */ private static String transformation = "AES/CBC/PKCS5Padding"; /** * 算法类型:用于指定生成AES的密钥 */ 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(charset), algorithm); //创建初始向量iv用于指定密钥偏移量(可自行指定但必须为128位),因为AES是分组加密,下一组的iv就用上一组加密的密文来充当 IvParameterSpec iv = new IvParameterSpec(key.getBytes(charset), 0, offset); //创建AES加密器 Cipher cipher = Cipher.getInstance(transformation); byte[] byteContent = content.getBytes(charset); //使用加密器的加密模式 cipher.init(Cipher.ENCRYPT_MODE, skey, iv); // 加密 byte[] result = cipher.doFinal(byteContent); //使用BASE64对加密后的二进制数组进行编码 return new Base64().encodeToString(result); } catch (Exception e) { log.info("", e); } 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(charset), 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,charset); } catch (Exception e) { log.info("", e); } return null; } public static void main(String[] args) { String s = "hello World!123.加解密"; String encryptResultStr = encrypt(s); // 加密 System.out.println("加密前:" + s); System.out.println("加密后:" + encryptResultStr); // 解密 System.out.println("解密后:" + decrypt(encryptResultStr)); } }