http://jingyan.baidu.com/article/db55b6099758134ba30a2f1a.html
Md5是一种散列算法,理论上是不可解密的,而且重复的几率极小极小,因此在平常的密码存储上应用比较广泛,这个值一般情况下是唯一的,所以在文件校验上也应用的比较多,下面说明一下C#中字符串以及文件获取Md5值方法。
-
1.首先是字符串获取Md5值,封装一个方法如下:
public static string GetMD5HashFromString(string str)
{
MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
byte[] bytValue, bytHash;
bytValue = System.Text.Encoding.UTF8.GetBytes(str);
bytHash = md5.ComputeHash(bytValue);
md5.Clear();
string sTemp = "";
for (int i = 0; i < bytHash.Length; i++)
{
sTemp += bytHash[i].ToString("X").PadLeft(2, '0');
}
return sTemp.ToUpper();
}
可以看到传进来的参数是一个字符串,而返回的值就是一个大写的字符串,获取这个字符串就是经过Md5加密之后的。调用的时候直接用此方法即可:GetMD5HashFromString("要加密的字符串");
-
2.下面是文件获取Md5值,依旧封装一个方法:
public static string GetMD5HashFromFile(string filePath)
{
try
{
FileStream file = new FileStream(filePath, FileMode.Open);
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
byte[] retVal = md5.ComputeHash(file);
file.Close();
StringBuilder sb = new StringBuilder();
for (int i = 0; i < retVal.Length; i++)
{
sb.Append(retVal[i].ToString("x2"));
}
return sb.ToString().ToUpper();
}
catch (Exception ex)
{
throw new Exception("GetMD5HashFromFile() fail,error:" + ex.Message);
}
}
可以看出这个传入的参数是一个文件路径,返回的同样是一个大写字符串,也是经过加密之后的,调用方法GetMD5HashFromFile("文件目录地址");由于是文件,可能会出现异常,所以加了一个try catch。
网上所说的Md5解密并不是真正的解密,因为Md5本就是一种不可解密的算法,其所称解密只是把一些常用的字符串获取Md5值,然后存入数据库,若是你输入Md5值在数据库里存在,那么就会返回与之对应的字符串了,若是没有就自然无法获取了,所以说密码还是要起的复杂些,加入一些特殊字符更好些。