C#实现Md5加密校验方法
Joe 于 2014-05-02 22:10:20 发布至 编程相关 累计 2704 次阅读
Md5是一种散列算法,理论上是不可解密的,即不可逆的,因此在平常的密码存储上应用比较广泛,加密之后的得到的字符串一般情况下是唯一的,所以在文件校验上应用广泛,下面分提供C#中字符串以及文件获取Md5值方法。首先是字符串获取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("要加密的字符串"); 下面是文件获取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值在数据库里存在,那么就会返回与之对应的字符串了,若是没有就自然无法获取了,所以说密码还是要起的复杂些,加入一些特殊字符更好些。