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


发布评论