• AES加密


    AES加密:双向,可以加密,也可以解密

    1.AES加密帮助类

        /// <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
  • 相关阅读:
    像asp.net Mvc一样开发nodejs+express Mvc站点
    js数组方法大全
    自己的时间规划
    7月暑假生活总结
    01. What Is Discrete Mathematics(中英字幕 by Ocean-藏心)
    找工作专题---二分查找
    angular.js 入门基础
    WCF实例管理
    是技术牛人,如何拿到国内IT巨头的Offer
    python
  • 原文地址:https://www.cnblogs.com/ywblog/p/4243303.html
Copyright © 2020-2023  润新知