AesTestOne.java 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. package com.template.common.utils;
  2. import com.template.config.ControlConfig;
  3. import org.apache.commons.codec.binary.Base64;
  4. import javax.annotation.Resource;
  5. import javax.crypto.Cipher;
  6. import javax.crypto.spec.IvParameterSpec;
  7. import javax.crypto.spec.SecretKeySpec;
  8. import java.io.UnsupportedEncodingException;
  9. import java.net.URLDecoder;
  10. import java.nio.charset.Charset;
  11. import java.nio.charset.StandardCharsets;
  12. /**
  13. * @Author: binguo
  14. * @Date: 2024/1/5 星期五 14:26
  15. * @Description: com.template.common.utils
  16. * @Version: 1.0
  17. */
  18. public class AesTestOne {
  19. /**
  20. * AES 对称加密(RSA非对称加密)
  21. * CBC 有向量 (ECB 无向量)
  22. * PKCS5Padding 填充模式(NoPadding 无填充)
  23. */
  24. private static final String ALG_AES_CBC_PKCS5 = "AES/CBC/PKCS5Padding";
  25. private static final String ALGORITHM = "AES";
  26. private static final Charset UTF8 = StandardCharsets.UTF_8;
  27. //private static String aesKey = "61afd794ed3244e995c5e894e5788193"; // 指定好的秘钥,非Base64和16进制
  28. private static String aesIv = "activevector4api"; // 偏移量
  29. private static SecretKeySpec skeySpec;
  30. private static IvParameterSpec iv;
  31. /**
  32. * 解密方法
  33. * @param cipherStr Base64编码的加密字符串
  34. * @return 解密后的字符串(UTF8编码)
  35. * @throws Exception 异常
  36. */
  37. public static String decrypt(String cipherStr, String appSecret) throws Exception{
  38. // step 1 获得一个密码器
  39. Cipher cipher = Cipher.getInstance(ALG_AES_CBC_PKCS5);
  40. // step 2 初始化密码器,指定是加密还是解密(Cipher.DECRYPT_MODE 解密; Cipher.ENCRYPT_MODE 加密)
  41. // 加密时使用的盐来够造秘钥对象
  42. skeySpec = new SecretKeySpec(appSecret.getBytes(),ALGORITHM);
  43. // 加密时使用的向量,16位字符串
  44. iv = new IvParameterSpec(aesIv.getBytes());
  45. cipher.init(Cipher.DECRYPT_MODE, skeySpec, iv);
  46. // 对加密报文进行base64解码
  47. byte[] encrypted1 = Base64.decodeBase64(cipherStr);
  48. // 解密后的报文数组
  49. byte[] original = cipher.doFinal(encrypted1);
  50. // 输出utf8编码的字符串,输出字符串需要指定编码格式
  51. return new String(original, UTF8);
  52. }
  53. /**
  54. * 加密
  55. * @param plainText 明文
  56. * @return Base64编码的密文
  57. * @throws Exception 加密异常
  58. */
  59. public static String encrypt(String plainText, String appSecret) throws Exception{
  60. Cipher cipher = Cipher.getInstance(ALG_AES_CBC_PKCS5);
  61. skeySpec = new SecretKeySpec(appSecret.getBytes(),ALGORITHM);
  62. iv = new IvParameterSpec(aesIv.getBytes());
  63. cipher.init(Cipher.ENCRYPT_MODE, skeySpec,iv);
  64. // 这里的编码格式需要与解密编码一致
  65. byte [] encryptText = cipher.doFinal(plainText.getBytes(UTF8));
  66. return Base64.encodeBase64String(encryptText);
  67. }
  68. public static void main(String[] args) throws Exception {
  69. // URL解码
  70. logger.info("");
  71. }
  72. }