C#实现Md5加密校验方法

Joe  于  2014-05-02 22:10:20  发布至  编程相关  累计    次阅读

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值在数据库里存在,那么就会返回与之对应的字符串了,若是没有就自然无法获取了,所以说密码还是要起的复杂些,加入一些特殊字符更好些。

上一篇:百度喜欢后分享下一篇:Wordpress因为谷歌导致后台慢解决办法