当前位置: 代码迷 >> 综合 >> AES encryption and decrytion
  详细解决方案

AES encryption and decrytion

热度:10   发布时间:2024-03-09 06:53:21.0
    public class AESHelper{/// <summary>/// 默认密钥-密钥的长度必须是32/// </summary>//private const string PublicKey = "123";static string PublicKey = System.Configuration.ConfigurationManager.AppSettings["AESKey"];/// <summary>/// 默认向量/// </summary>//private const string Iv = "123";static string Iv = System.Configuration.ConfigurationManager.AppSettings["AESV"];/// <summary>  /// AES加密  /// </summary>  /// <param name="str">需要加密字符串</param>  /// <returns>加密后字符串</returns>  public static String Encrypt(string str){return Encrypt(str, PublicKey);}/// <summary>  /// AES解密  /// </summary>  /// <param name="str">需要解密字符串</param>  /// <returns>解密后字符串</returns>  public static String Decrypt(string str){return Decrypt(str, PublicKey);}/// <summary>/// AES加密/// </summary>/// <param name="str">需要加密的字符串</param>/// <param name="key">32位密钥</param>/// <returns>加密后的字符串</returns>public static string Encrypt(string str, string key){Byte[] keyArray = System.Text.Encoding.UTF8.GetBytes(key);Byte[] toEncryptArray = System.Text.Encoding.UTF8.GetBytes(str);var rijndael = new System.Security.Cryptography.RijndaelManaged();rijndael.Key = keyArray;rijndael.Mode = System.Security.Cryptography.CipherMode.CBC;rijndael.Padding = System.Security.Cryptography.PaddingMode.PKCS7;rijndael.IV = System.Text.Encoding.UTF8.GetBytes(Iv);System.Security.Cryptography.ICryptoTransform cTransform = rijndael.CreateEncryptor();Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);return Convert.ToBase64String(resultArray, 0, resultArray.Length);}/// <summary>/// AES解密/// </summary>/// <param name="str">需要解密的字符串</param>/// <param name="key">32位密钥</param>/// <returns>解密后的字符串</returns>public static string Decrypt(string str, string key){Byte[] keyArray = System.Text.Encoding.UTF8.GetBytes(key);Byte[] toEncryptArray = Convert.FromBase64String(str);var rijndael = new System.Security.Cryptography.RijndaelManaged();rijndael.Key = keyArray;rijndael.Mode = System.Security.Cryptography.CipherMode.CBC;rijndael.Padding = System.Security.Cryptography.PaddingMode.PKCS7;rijndael.IV = System.Text.Encoding.UTF8.GetBytes(Iv);System.Security.Cryptography.ICryptoTransform cTransform = rijndael.CreateDecryptor();Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);return System.Text.Encoding.UTF8.GetString(resultArray);}}