MD5算法说明: 加密算法都是对字节数组或流进行加密的。MD5的算法则是对原始的字节数组随机(有算法的随机)抽取几个字节,经过运算后返回新的字节(加密以后的字节)。它不 仅可以对字符串进行加密,也可以对文件进行加密。加密以后的数据已经不同于原始的数据,随机抽取字节导致不可逆。内部算法又保证对相同字符串加密的结果相同。MD5值是有限的,但是源数据是无限的,所以存在不同的内容加密后得到相同MD5值的情况(这里也可以看出它的不可逆性)。但是这个概率非常低,所以,我们在给用户密码加密时,一般不考虑这种情况。
一、对字符串加密
/// 加密字符串
/// </summary>
/// <param name="str">要加密的字符串</param>
/// <returns>加密后的字符串(MD5值)</returns>
private string MD5EncryptionString(string str)
{
MD5CryptoServiceProvider md5Provider = new MD5CryptoServiceProvider();
byte[] temp=System.Text.Encoding.ASCII.GetBytes(str);
byte[] md5Byte=md5Provider.ComputeHash(temp);
//直接将字节数据转换成字符串发现发乱码,是因为这个字节数组不一定就是某个字符或字符串的字节数组。
//string md5Value = System.Text.Encoding.ASCII.GetString(md5Byte);
string md5Value = string.Empty;
//整个字节数组转不成功,我们就转换它的每一个字节,将每一个字节转换成十六进制数
//1.“x”表示十六进制小写
//2.“X”表示十六进制大写
foreach (var item in md5Byte)
{
md5Value += item.ToString("x2");
}
return md5Value;
}
二、对文件加密
/// <summary>
/// 加密文件
/// </summary>
/// <param name="filePath">文件路径</param>
/// <returns>加密后的字符串</returns>
private string MD5EncryptionFile(string filePath)
{
MD5CryptoServiceProvider provider = new MD5CryptoServiceProvider();
byte[] md5Byte = null;
string md5Value = string.Empty;
using(FileStream fs=new FileStream (filePath,FileMode.Open))
{
md5Byte = provider.ComputeHash(fs);
}
foreach (var item in md5Byte)
{
md5Value += item.ToString("x2");
}
return md5Value;
}