C#實現MD5加密 解密

最近在搞一個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());

        }


    }
}

`

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章