AES加密

AES加密:雙向,能夠加密,也能夠解密數組

1.AES加密幫助類ide

    /// <summary>
    /// AES對稱加密解密類
    /// </summary>
    public class AESHelper
    {
        #region 成員變量
        /// <summary>
        /// 密鑰
        /// </summary>
        private static string _passwd = "ihlih*0037JOHT*)(PIJY*(()JI^)IO%";

        /// <summary>
        /// 密鑰位數
        /// </summary>
        private const int _passwdLength = 32;

        /// <summary>
        /// 運算模式
        /// </summary>
        private static CipherMode _cipherMode = CipherMode.ECB;
        /// <summary>
        /// 填充模式
        /// </summary>
        private static PaddingMode _paddingMode = PaddingMode.PKCS7;
        /// <summary>
        /// 字符串採用的編碼
        /// </summary>
        private static Encoding _encoding = Encoding.UTF8;
        #endregion

        #region 輔助方法
        /// <summary>
        /// 獲取byte密鑰數據
        /// </summary>
        /// <param name="password">密碼</param>
        /// <returns></returns>
        private static byte[] GetKeyArray(string password)
        {
            if (password == null)
            {
                password = string.Empty;
            }

            if (password.Length < _passwdLength)
            {
                password = password.PadRight(_passwdLength, '0');
            }
            else if (password.Length > _passwdLength)
            {
                password = password.Substring(0, _passwdLength);
            }

            return _encoding.GetBytes(password);
        }

        /// <summary>
        /// 將字符數組轉換成字符串
        /// </summary>
        /// <param name="inputData"></param>
        /// <returns></returns>
        private static string ConvertByteToString(byte[] inputData)
        {
            StringBuilder sb = new StringBuilder(inputData.Length * 2);
            foreach (var b in inputData)
            {
                sb.Append(b.ToString("X2"));
            }
            return sb.ToString();
        }

        /// <summary>
        /// 將字符串轉換成字符數組
        /// </summary>
        /// <param name="inputString"></param>
        /// <returns></returns>
        private static byte[] ConvertStringToByte(string inputString)
        {
            if (inputString == null || inputString.Length < 2)
            {
                throw new ArgumentException();
            }

            if ((inputString.Length % 2) != 0)
            {
                inputString += " ";
            }

            int l = inputString.Length / 2;
            byte[] result = new byte[l];
            for (int i = 0; i < l; ++i)
            {
                result[i] = Convert.ToByte(inputString.Substring(2 * i, 2), 16);
            }

            return result;
        }
        #endregion

        #region 加密
        /// <summary>
        /// 加密字節數據
        /// </summary>
        /// <param name="inputData">要加密的字節數據</param>
        /// <param name="password">密碼</param>
        /// <returns></returns>
        public static byte[] Encrypt(byte[] inputData, string password)
        {
            using (AesCryptoServiceProvider aes = new AesCryptoServiceProvider())
            {
                aes.Key = GetKeyArray(password);
                aes.Mode = _cipherMode;
                aes.Padding = _paddingMode;
                ICryptoTransform transform = aes.CreateEncryptor();
                byte[] data = transform.TransformFinalBlock(inputData, 0, inputData.Length);
                aes.Clear();
                return data;
            }
        }

        /// <summary>
        /// 加密字符串(加密爲16進制字符串)
        /// </summary>
        /// <param name="inputString">要加密的字符串</param>
        /// <param name="password">密碼</param>
        /// <returns></returns>
        public static string Encrypt(string inputString, string password)
        {
            if (string.IsNullOrWhiteSpace(inputString) || string.IsNullOrWhiteSpace(password))
            {
                return string.Empty;
            }

            byte[] toEncryptArray = _encoding.GetBytes(inputString);
            byte[] result = Encrypt(toEncryptArray, password);
            return ConvertByteToString(result);
        }

        /// <summary>
        /// 字符串加密(加密爲16進制字符串)
        /// </summary>
        /// <param name="inputString">須要加密的字符串</param>
        /// <returns>加密後的字符串</returns>
        public static string EncryptString(string inputString)
        {
            if (string.IsNullOrWhiteSpace(_passwd))
            {
                throw new ArgumentException("密鑰不能爲空");
            }
            return Encrypt(inputString, _passwd);
        }
        #endregion

        #region 解密
        /// <summary>
        /// 解密字節數組
        /// </summary>
        /// <param name="inputData">要解密的字節數據</param>
        /// <param name="password">密碼</param>
        /// <returns></returns>
        public static byte[] Decrypt(byte[] inputData, string password)
        {
            using (AesCryptoServiceProvider aes = new AesCryptoServiceProvider())
            {
                aes.Key = GetKeyArray(password);
                aes.Mode = _cipherMode;
                aes.Padding = _paddingMode;
                ICryptoTransform transform = aes.CreateDecryptor();
                byte[] data = null;
                try
                {
                    data = transform.TransformFinalBlock(inputData, 0, inputData.Length);
                }
                catch
                {
                    return null;
                }
                aes.Clear();
                return data;
            }
        }

        /// <summary>
        /// 解密16進制的字符串爲字符串
        /// </summary>
        /// <param name="inputString">要解密的字符串</param>
        /// <param name="password">密碼</param>
        /// <returns>字符串</returns>
        public static string Decrypt(string inputString, string password)
        {
            if (string.IsNullOrWhiteSpace(inputString) || string.IsNullOrWhiteSpace(password))
            {
                return string.Empty;
            }
            byte[] toDecryptArray = ConvertStringToByte(inputString);
            string decryptString = _encoding.GetString(Decrypt(toDecryptArray, password));
            return decryptString;
        }

        /// <summary>
        /// 解密16進制的字符串爲字符串
        /// </summary>
        /// <param name="inputString">須要解密的字符串</param>
        /// <returns>解密後的字符串</returns>
        public static string DecryptString(string inputString)
        {
            if (string.IsNullOrWhiteSpace(_passwd))
            {
                throw new ArgumentException("密鑰不能爲空");
            }
            return Decrypt(inputString, _passwd);
        }
        #endregion
    }
View Code
相關文章
相關標籤/搜索