> 백엔드 개발 > C#.Net 튜토리얼 > asp.net 암호화 및 암호 해독 클래스

asp.net 암호화 및 암호 해독 클래스

伊谢尔伦
풀어 주다: 2016-11-25 09:40:30
원래의
1376명이 탐색했습니다.

다음은 MD5, SHA1, DES 암호화 및 복호화, Base64 인코딩 및 디코딩을 포함하여 admin10000.com에서 제공하는 미리 만들어진 C# 암호화 및 복호화 클래스입니다.

먼저 www.Admin10000.com에서 네임스페이스

      using System.Web.Security; 
    using System.Security.Cryptography; 
    using System.Text; 
    using System.IO;
로그인 후 복사

///


/// EncryptHelper를 가져옵니다.
///

public class EncryptHelper
{
        // 提供8个字符作为DES密钥(程序自动截取前8个字符) 
        private static string key = "admin10000.com";
        /// <summary>
        /// DES对称加密解密的密钥
        /// </summary> 
        public static string Key
        {
                get
                {
                        return key;
                }
                set
                {
                        key = value;
                }
        }
        /// <summary>
        /// MD5 加密(不可逆加密)
        /// </summary>
        /// <param name="pass">要加密的原始字串</param>
        /// <returns></returns> 
        public static string MD5Encrypt(string pass)
        {    
                System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
                byte[] bytResult = md5.ComputeHash(System.Text.Encoding.UTF8.GetBytes(pass));
                md5.Clear();
                string strResult = BitConverter.ToString(bytResult);
                strResult = strResult.Replace("-", "");
                return strResult;        
                /* 另一种方法
                pass = FormsAuthentication.HashPasswordForStoringInConfigFile(pass, "MD5");
                return pass;
                */    
        }
        /// <summary>
        /// SHA1 加密(不可逆加密)
        /// </summary>
        /// <param name="pass">要加密的原始字串</param>
        /// <returns></returns> 
        public static string SHA1Encrypt(string pass)
        {
                System.Security.Cryptography.SHA1 sha1 = new System.Security.Cryptography.SHA1CryptoServiceProvider();
                byte[] bytResult = sha1.ComputeHash(System.Text.Encoding.UTF8.GetBytes(pass));
                sha1.Clear();
                string strResult = BitConverter.ToString(bytResult);
                strResult = strResult.Replace("-", "");
                return strResult;
                /* 另一种方法
                pass = FormsAuthentication.HashPasswordForStoringInConfigFile(pass, "SHA1");
                return pass;
                */
        }
        /// <summary>
        /// DES加密字符串
        /// </summary>
        /// <param name="encryptString">待加密的字符串</param>
        /// <returns>加密成功返回加密后的字符串,失败返回源串</returns> 
        public static string DESEncrypt(string encryptString)
        {
                try
                {
                        byte[] rgbKey = Encoding.UTF8.GetBytes(key.Substring(0, 8));
                        byte[] rgbIV = rgbKey;
                        byte[] inputByteArray = Encoding.UTF8.GetBytes(encryptString);
                        DESCryptoServiceProvider dCSP = new DESCryptoServiceProvider();
                        MemoryStream mStream = new MemoryStream();
                        CryptoStream cStream = new CryptoStream(mStream, dCSP.CreateEncryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
                        cStream.Write(inputByteArray, 0, inputByteArray.Length);
                        cStream.FlushFinalBlock();
                        cStream.Close();
                        return Convert.ToBase64String(mStream.ToArray());
                }
                catch
                {
                        return encryptString;
                }
        }
        /// <summary>
        /// DES解密字符串
        /// </summary>
        /// <param name="decryptString">待解密的字符串</param>
        /// <returns>解密成功返回解密后的字符串,失败返源串</returns> 
        public static string DESDecrypt(string decryptString)
        {
                try
                {
                        byte[] rgbKey = Encoding.UTF8.GetBytes(key.Substring(0, 8));
                        byte[] rgbIV = rgbKey;
                        byte[] inputByteArray = Convert.FromBase64String(decryptString);
                        DESCryptoServiceProvider DCSP = new DESCryptoServiceProvider();
                        MemoryStream mStream = new MemoryStream();
                        CryptoStream cStream = new CryptoStream(mStream, DCSP.CreateDecryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
                        cStream.Write(inputByteArray, 0, inputByteArray.Length);
                        cStream.FlushFinalBlock();
                        cStream.Close();
                        return Encoding.UTF8.GetString(mStream.ToArray());
                }
                catch
                {
                        return decryptString;
                }
        }
        /// <summary>
        /// 将普通字符串编码为BASE64字串
        /// </summary>
        /// <param name="str">源字符串</param>
        /// <returns></returns> 
        public static string Base64Encode(string str)
        {
                return Convert.ToBase64String(Encoding.UTF8.GetBytes(str));
        }
        /// <summary>
        /// 解码BASE64字串
        /// </summary>
        /// <param name="str">Base64字串</param>
        /// <returns></returns> 
        public static string Base64Decode(string base64Str)
        {
                return Encoding.UTF8.GetString(Convert.FromBase64String(base64Str));
        }
}
로그인 후 복사


관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿