本文介绍: 需要加密字符串/// 需要解密的字符串/// 原始字符串/// 密匙MD5加密字符串/// 加密后的字符串/// 解密后的字符串

public class DEncryptHelper
    {
        #region Md5加密

        /// <summary>
        /// 获取字符串MD5加密字符串
        /// </summary>
        /// <param name=”str”>原始字符串</param>
        /// <returns>MD5加密字符串</returns>
        public static string GetMd5(string str)
        {
            var pwd = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(str, “MD5”);
            return pwd;
        }
        #endregion

        #region 可逆加密 解密

        /// <summary>
        /// 加密方法
        /// </summary>
        /// <param name=”encryptionStr”>需要加密字符串</param>
        /// <param name=”key”>密钥 8位 不够补0,超出截取</param>
        /// <returns>加密后的字符串</returns>
        public static string Encrypt(string encryptionStr, string key)
        {
            key = GetKey(key);
            DESCryptoServiceProvider DES = new DESCryptoServiceProvider();
            //把字符串放到byte数组中

            //原来使用的UTF8编码,我改成Unicode编码了,不行
            byte[] byt = Encoding.Default.GetBytes(encryptionStr);

            //建立加密对象的密钥和偏移量
            //使得输入密码必须输入英文文本
            DES.Key = ASCIIEncoding.ASCII.GetBytes(key);
            DES.IV = ASCIIEncoding.ASCII.GetBytes(key);
            MemoryStream ms = new MemoryStream();
            CryptoStream cs = new CryptoStream(ms, DES.CreateEncryptor(), CryptoStreamMode.Write);

            cs.Write(byt, 0, byt.Length);
            cs.FlushFinalBlock();
            StringBuilder ret = new StringBuilder();
            foreach (byte b in ms.ToArray())
            {
                ret.AppendFormat(“{0:X2}”, b);
            }
            ret.ToString();
            return ret.ToString();
        }

        /// <summary> 
        /// 解密方法 需要参数 
        /// </summary>
        /// <param name=”decryptStr”>需要解密的字符串</param>
        /// <param name=”key”>密匙</param>
        /// <returns>解密后的字符串</returns>
        public static string Decrypt(string decryptStr, string key)
        {
            key = GetKey(key);
            DESCryptoServiceProvider DES = new DESCryptoServiceProvider();
            byte[] byt = new byte[decryptStr.Length / 2];
            for (int x = 0; x < decryptStr.Length / 2; x++)
            {
                int i = (Convert.ToInt32(decryptStr.Substring(x * 2, 2), 16));
                byt[x] = (byte)i;
            }

            //建立加密对象的密钥和偏移量,此值重要,不能修改
            DES.Key = ASCIIEncoding.ASCII.GetBytes(key);
            DES.IV = ASCIIEncoding.ASCII.GetBytes(key);
            MemoryStream ms = new MemoryStream();
            CryptoStream cs = new CryptoStream(ms, DES.CreateDecryptor(), CryptoStreamMode.Write);
            cs.Write(byt, 0, byt.Length);
            cs.FlushFinalBlock();
            //建立StringBuild对象,CreateDecrypt使用的是流对象,必须把解密后的文本变成流对象
            StringBuilder ret = new StringBuilder();
            var str = System.Text.Encoding.Default.GetString(ms.ToArray());
            return str;
        }

        private static string GetKey(string key)
        {
            if (key.Length < 8)//补0
            {
                var count = 8 – key.Length;
                for (int i = 0; i < count; i++)
                {
                    key += “0”;
                }
            }
            else if (key.Length > 8)
            {
                key = key.Substring(0, 8);
            }
            return key;
        }
        #endregion 
    }

原文地址:https://blog.csdn.net/vbloveshllm/article/details/136052477

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_67679.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注