MD5多种加密方式

37 篇文章 0 订阅

加密 

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Runtime.Serialization.Formatters.Binary;
using System.Security.Cryptography;
using System.Text;
using log4net;
 
namespace Utility
{
    /// <summary>
    /// @Author:梁继龙
    /// @Date:2012/7/30
    /// @Descripte:EncryptHelper加密帮助类.
    /// </summary>
    public class EncryptHelper
    {
        /// <summary>
        ///方法一:
        ///此种加密之后的字符串是三十二位的(字母加数据)字符串  
        /// Example: password是admin 加密变成后21232f297a57a5a743894a0e4a801fc3
        /// </summary>
        /// <param name="beforeStr"></param>
        /// <returns></returns>
        public string MD5Encrypt(string beforeStr)
        {
            string afterString = "";
            try
            {
                MD5 md5 = MD5.Create();
                byte[] hashs = md5.ComputeHash(Encoding.UTF8.GetBytes(beforeStr));
 
                foreach (byte by in hashs)
                    //这里是字母加上数据进行加密.//3y 可以,y3不可以或 x3j等应该是超过32位不可以
                    afterString += by.ToString("x2");
            }
            catch (Exception ex)
            {
                ILog log = log4net.LogManager.GetLogger(this.GetType());
                log.Error("==============你引起了一个错误是==============" + ex.Message.ToString());
            }
            return afterString;
        }
 
        /// <summary>
        /// 方法二
        /// HashAlgorithm加密
        /// 这种加密是  字母加-加字符  
        /// Example: password是admin 加密变成后19-A2-85-41-44-B6-3A-8F-76-17-A6-F2-25-01-9B-12
        /// </summary>
        /// <param name="password"></param>
        /// <returns></returns>
        public String HashEncrypt(string password)
        {
            Byte[] hashedBytes = null;
            try
            {
                Byte[] clearBytes = new UnicodeEncoding().GetBytes(password);
                hashedBytes = ((HashAlgorithm)CryptoConfig.CreateFromName("MD5")).ComputeHash(clearBytes);
            }
            catch (Exception ex)
            {
                ILog log = log4net.LogManager.GetLogger(this.GetType());
                log.Error("==============你引起了一个错误是==============" + ex.Message.ToString());
            }
            return BitConverter.ToString(hashedBytes);//MD5加密
        }
 
        /// <summary>
        /// 方法三:
        /// MD5  +   HashCode加密
        /// Example: password是admin 加密变成后 895b7da64943134be17b825ce118456c
        /// </summary>
        /// <returns></returns>
        public String MD5HashCodeEncrypt(string EncryptPwd)
        {
            return MD5Encrypt(HashEncrypt(EncryptPwd)); //在HashEncrypt基础上再MD5
        }
 
        /// <summary>
        /// 方法四:
        /// HashCode +MD5 加密
        /// Example: password是admin 加密变成后EB-1D-6D-E2-FC-F1-CD-94-4D-75-78-E6-3D-7A-12-32
        /// </summary>
        /// <param name="EncryptPwd"></param>
        /// <returns></returns>
        public String HashCodeMD5Encrypt(string EncryptPwd)
        {
            return HashEncrypt(MD5Encrypt(EncryptPwd)); //在MD5基础再HashCode
        }
        /// <summary>
        /// 方法五
        /// </summary>
        /// <param name="EncryptPwd"></param>
        /// <returns></returns>
 
        public String HashMD5Encrypt(string EncryptPwd)
        {
            return HashCodeMD5Encrypt(HashCodeMD5Encrypt(EncryptPwd)); //在HashCodeMD5Encrypt基础再HashCode
        }
        /// <summary>
        /// 方法六
        /// 哈哈是不是有点晕呢?
        /// 大家伙可以继续写.
        /// </summary>
        /// <param name="EncryptPwd"></param>
        /// <returns></returns>
        public String MD5HashEncrypt(string EncryptPwd)
        {
            return MD5HashCodeEncrypt(MD5HashCodeEncrypt(EncryptPwd)); //在MD5基础再HashCode
        }
        /// <summary>
        /// 64位双重MD5小写
        /// </summary>
        /// <returns></returns>
        public static string Last64(string s)
        {
            if (s.Length != 32)
                return "";
            string s1 = s.Substring(0, 16);
            string s2 = s.Substring(16, 16);
            return Lower32(s1) + Lower32(s2);
        }
        /// <summary>
        /// 32位大写
        /// </summary>
        /// <returns></returns>
        public static string Upper32(string s)
        {
            s = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5").ToString();
            return s.ToUpper();
        }
        /// <summary>
        /// 32位小写
        /// </summary>
        /// <returns></returns>
        public static string Lower32(string s)
        {
            s = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5").ToString();
            return s.ToLower();
        }
        /// <summary>
        /// 16位大写
        /// </summary>
        /// <returns></returns>
        public static string Upper16(string s)
        {
            s = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5").ToString();
            return s.ToUpper().Substring(8, 16);
        }
        /// <summary>
        /// 16位小写
        /// </summary>
        /// <returns></returns>
        public static string Lower16(string s)
        {
            s = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5").ToString();
            return s.ToLower().Substring(8, 16);
        }
    }
 
}

解密 

public static bool VerifyMd5Hash(string userInput, string hashDataSet)
        {
            // Hash the userInput.
            string hashOfInput = GetMd5Hash(userInput);

            // Create a StringComparer an compare the hashes.
            StringComparer comparer = StringComparer.OrdinalIgnoreCase;

            if (0 == comparer.Compare(hashOfInput, hashDataSet))
            {
                return true;
            }
            else
            {
                return false;
            }
        }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值