1. 程式人生 > >C#之演算法加密一:AES加解密

C#之演算法加密一:AES加解密

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;
        }