最近在搞一个C#的MD5加密,个人了解由于在ASP.Net中引用 System.Web.Security就可以使用里面的一个简单的MD5加密,但是,现在我想做的是,直接使用System.Security这一个安 全模块。在查阅了MSDN的说明后,发现有二种的正常的方法:

using System;
using System.Security;
using System.Security.Cryptography;
using System.Text;

然后,

    MD5CryptoServiceProvider md5=new MD5CryptoServiceProvider();
    string t2=BitConverter.ToString(md5.ComputeHash(UTF8Encoding.Default.GetBytes(sinText)));
    t2=t2.Replace("-","");
    soutText=t2;
    return t2;

以上会产生一个16位的加密MD5数组,转换成字符串后长度是32,但是,由于我们现在的ASP代码中的MD5加密一般是16长度的,所以,可以使用下面的方法:

    MD5CryptoServiceProvider md5=new MD5CryptoServiceProvider();
    string t2=BitConverter.ToString(md5.ComputeHash(UTF8Encoding.Default.GetBytes(sinText)),4,8);
    t2=t2.Replace("-","");
    soutText=t2;
    return t2;

以上使用的是 System.Text.BinConverter来转换数组到字符串,一开始我直接使用UTF8Encoding.Default.GetString(b),却常常得不到正常的值。可能那个有一些问题吧。

如果大家不想使用上面的 BitConverter,那么,你还可以使用以下的方法:

StringBuilder sb=new StringBuilder();
for(int i=0;i<b.length;i++)
{
    sb.Append(b[i].ToString("x2");
}
return sb.ToString();

以上也可以达到将加密后的数据转化成正常的字符串,这个是英文MSDN中的用法

 

 

解密实例:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Security.Cryptography;

namespace MD5
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            textBox2.Text=GetMd5Str(textBox1.Text.Trim());
        }
        /**/
        /// <summary>
        /// MD5 16位加密
        /// </summary>
        /// <param name="ConvertString"></param>
        /// <returns></returns>
        public static string GetMd5Str(string ConvertString)
        {
            MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
            string t2 = BitConverter.ToString(md5.ComputeHash(UTF8Encoding.Default.GetBytes(ConvertString)), 4, 8);
            t2 = t2.Replace("-", "");
            return t2;
        }
        /**/
        /// <summary>
        /// MD5 32位加密
        /// </summary>
        /// <param name="str"></param>
        /// <returns></returns>
        static string UserMd5(string str)
        {
            string cl = str;
            string pwd = "";
            string temp = "";
            MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
            // 加密后是一个字节类型的数组,这里要注意编码UTF8/Unicode等的选择 
            byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(cl));
            // 通过使用循环,将字节类型的数组转换为字符串,此字符串是常规字符格式化所得
            for (int i = 0; i < s.Length; i++)
            {
                // 将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X)则格式后的字符是大写字符
                temp=s[i].ToString("X");
                if(temp.Length<2)
                    temp="0"+temp;
                pwd = pwd + temp;
            }
            return pwd;
        }

        private void button2_Click(object sender, EventArgs e)
        {

            textBox3.Text = UserMd5(textBox1.Text.Trim());

        }


    }
}