AesTool.cs 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. //############################################################
  2. // https://github.com/yuzhengyang
  3. // author:yuzhengyang
  4. //############################################################
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Linq;
  8. using System.Security.Cryptography;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. namespace Y.Utils.DataUtils.EncryptUtils
  12. {
  13. public class AesTool
  14. {
  15. public static string Encrypt(string s, string key)
  16. {
  17. //byte[] keyArray = UTF8Encoding.UTF8.GetBytes("12345678901234567890123456789012");
  18. byte[] keyArray = UTF8Encoding.UTF8.GetBytes(key);
  19. byte[] toEncryptArray = UTF8Encoding.UTF8.GetBytes(s);
  20. RijndaelManaged rDel = new RijndaelManaged();
  21. rDel.Key = keyArray;
  22. rDel.Mode = CipherMode.ECB;
  23. rDel.Padding = PaddingMode.PKCS7;
  24. ICryptoTransform cTransform = rDel.CreateEncryptor();
  25. byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
  26. return Convert.ToBase64String(resultArray, 0, resultArray.Length);
  27. }
  28. public static string Decrypt(string s, string key)
  29. {
  30. byte[] keyArray = UTF8Encoding.UTF8.GetBytes(key);
  31. byte[] toEncryptArray = Convert.FromBase64String(s);
  32. RijndaelManaged rDel = new RijndaelManaged();
  33. rDel.Key = keyArray;
  34. rDel.Mode = CipherMode.ECB;
  35. rDel.Padding = PaddingMode.PKCS7;
  36. ICryptoTransform cTransform = rDel.CreateDecryptor();
  37. byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
  38. return UTF8Encoding.UTF8.GetString(resultArray);
  39. }
  40. }
  41. }