C# MD5(16/32)
2011-02-23 15:11
225 查看
最近在搞一个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());
}
}
}
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());
}
}
}
相关文章推荐
- C#:循环冗余校验CRC-16-CCITT和CRC-32-IEEE 802.3
- C#中MD5 - 16/32位加密实例
- C#:循环冗余校验CRC-16-CCITT和CRC-32-IEEE 802.3
- C#:循环冗余校验CRC-16-CCITT和CRC-32-IEEE 802.3
- CRC-32 CRC-16 校验算法 C# 代码
- vba md5 加密(支持16,32)
- C#:UTF-8、UTF-16、UTF-32之间的编码转换
- MD5大小写,32,16
- 技术点-MD5密码加密-32/16 位
- 我自己简单写的32转换成 16 位的MD5方式
- Unicode、UCS、UTF-8、UTF-16、UTF-32 的关系
- 外设位宽为8、16、32时,CPU与外设之间地址线的连接方法
- c# 如何给文件计算MD5
- C# MD5 16进制MD5对称加密法
- JAVA程序员面试32问,你能回答多少题? --- 答案(16-32)
- C# 字符串 MD5
- 解决 c# MD5生成时失败
- Adler-32校验算法 C#实现
- VS2015 C#生成dll文件的方法(32/64)
- FLASH位宽为8、16、32时,CPU与外设之间地址线的连接方法