MD5即Message-Digest Algorithm 5(信息-摘要算法5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD5实现。将数据(如汉字)运算为另一固定长度值,是杂凑算法的基础原理,MD5的前身有MD2、MD3和MD4。
MD5算法具有以下特点:
1、压缩性:任意长度的数据,算出的MD5值长度都是固定的。
2、容易计算:从原数据计算出MD5值很容易。
3、抗修改性:对原数据进行任何改动,哪怕只修改1个字节,所得到的MD5值都有很大区别。
4、强抗碰撞:已知原数据和其MD5值,想找到一个具有相同MD5值的数据(即伪造数据)是非常困难的。
MD5的作用是让大容量信息在用数字签名软件签署私人密钥前被"压缩"成一种保密的格式(就是把一个任意长度的字节串变换成一定长的十六进制数字串)。除了MD5以外,其中比较有名的还有sha-1、RIPEMD以及Haval等。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Security.Cryptography;
using System.IO;
namespace Common
{
class MD5Helper
{
/// <summary>
/// 获取字符串MD5值
/// </summary>
/// <param name="sText"></param>
/// <param name="encoding">编码方式</param>
/// <param name="uppercase">true 大写;false 小写</param>
/// <returns></returns>
public static string Encrypt(string sText, Encoding encoding, bool uppercase=true)
{
byte[] buffer = encoding.GetBytes(sText);
string s = Encrypt(buffer);
if (!uppercase)
s = s.ToLower();
return s;
}
/// <summary>
/// 获取字符串MD5值
/// </summary>
/// <param name="buffer"></param>
/// <returns></returns>
public static string Encrypt(byte[] buffer)
{
//使用MD5这个抽象类的Creat()方法创建一个虚拟的MD5类的对象。
using (MD5 md5 = MD5.Create())
{
//使用MD5实例的ComputerHash()方法处理字节数组。
byte[] bufferNew = md5.ComputeHash(buffer);
string s = BitConverter.ToString(bufferNew, 0, bufferNew.Length);
return s.Replace("-", "");
}
}
/// <summary>
/// 获取流MD5值
/// </summary>
/// <param name="inputStream"></param>
/// <returns></returns>
public static string Encrypt(Stream inputStream)
{
using (MD5 mi = MD5.Create())
{
//开始加密
byte[] bufferNew = mi.ComputeHash(inputStream);
string s = BitConverter.ToString(bufferNew, 0, bufferNew.Length);
return s.Replace("-", "");
}
}
/// <summary>
/// 获取文件MD5值
/// </summary>
/// <param name="filename"></param>
/// <returns></returns>
public static string EncryptFile(string filename)
{
using (FileStream fs = new FileStream(filename, FileMode.Open))
{
return Encrypt(fs);
}
}
}
}