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