C#之演算法加密一:AES加解密
阿新 • • 發佈:2018-11-07
AES:是高階加密標準,在密碼學中又稱Rijndael加密法,是美國聯邦政府採用的一種區塊加密標準。這個標準主要是代替原先的DES,以及被多方分析且廣為全世界所使用。
AES加密資料塊分組長度必須是128位元,金鑰長度可以使128位元,192位元,256位元中的任意一個(如果資料塊及金鑰 長度不足時,會補齊)。AES加密有很多輪的重複和變換。大致的步驟是:1、金鑰的擴充套件(KeyExpansion),2、初始輪(InitialRound),3.重複輪(Rounds),每一輪又包括:SubBytes、ShiftRows、MixColumns、AddRoundKey,4、最終輪(FinalRound),最終輪沒有MixColumns。
以下展示一個小小的案例,參考學習:
//預設金鑰向量 private static byte[] _Aeskey = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF, 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF }; /// <summary> /// AES加密,返回Base64編碼後的字元 /// </summary> /// <param name="plainText">明文字串</param> /// <param name="strKey">金鑰</param> /// <returns>返回加密後的Base64編碼字串</returns> public static string EncryptAES(string plainText, string strKey="123456") { byte[] byteArray = Encoding.UTF8.GetBytes(plainText); Byte[] bKey = new Byte[32]; Array.Copy(Encoding.UTF8.GetBytes(strKey.PadRight(bKey.Length)), bKey, bKey.Length); RijndaelManaged rDel = new RijndaelManaged(); // rDel.Key = Encoding.UTF8.GetBytes(strKey); rDel.Key = bKey; rDel.IV = _Aeskey; rDel.BlockSize = 128; rDel.Mode = CipherMode.ECB;//設定為ECB rDel.Padding = PaddingMode.PKCS7;//設定為PKCS7,否則解密後字串結尾會出現多餘字元 ICryptoTransform cTransform = rDel.CreateEncryptor(); var s = cTransform.TransformFinalBlock(byteArray, 0, byteArray.Length); var encrypt = Convert.ToBase64String(s); rDel.Clear(); return encrypt; } /// <summary> /// AES解密,返回解密後的字串 /// </summary> /// <param name="cipherText">Base64編碼的密文</param> /// <param name="strKey">金鑰</param> /// <returns>返回解密後的字串</returns> public static string DecryptAES(string cipherText, string strKey="123456") { byte[] byteArray = Convert.FromBase64String(cipherText); Byte[] bKey = new Byte[32]; Array.Copy(Encoding.UTF8.GetBytes(strKey.PadRight(bKey.Length)), bKey, bKey.Length); RijndaelManaged rDel = new RijndaelManaged(); rDel.Key = bKey; rDel.IV = _Aeskey; rDel.BlockSize = 128; rDel.Mode = CipherMode.ECB;//必須設定為ECB,要與加密的模式一致 rDel.Padding = PaddingMode.PKCS7;//必須設定為PKCS7,要與加密的模式一致 ICryptoTransform cTransform = rDel.CreateDecryptor(); var s = cTransform.TransformFinalBlock(byteArray, 0, byteArray.Length); var decrypt = Encoding.UTF8.GetString(s); rDel.Clear(); return decrypt; }