数据加密之MD5加密

时间:2023-03-09 02:18:45
数据加密之MD5加密

MD5是一个安全的散列算法,有两个特点:
1、输入两个不同的明文(一段原始的数字信息)不会得到相同的输出值
2、根据输出值,不能得到原始的明文,即过程不可逆
所以要解密MD5没有现成的算法,只能用穷举法,把可能出现的明文,用MD5算法散列之后,把得到的散列值和原始的数据形成一个一对一的映射表,然后在所谓的解密的时候,都是通过这个映射表来查找其所对应的原始明文。
而绝对没有一种算法,可以通过输出加密后的散列值算出原始明文。

了解更多看百度百科:

http://baike.baidu.com/link?url=R7WBookslKWRvprcZ6o4ZkurlXDPTaCqr6kTzT1WWIPwTgb5eRpi2e6dVXMEKoM_

http://baike.baidu.com/link?url=HsaSyVnnJ3n2Ep2XVoSPv0SBJRvCY0Zm18MqDZIvvkJUwSZvgz4yS9upDY_YTVcVBOpUZUxFVyio4r_yY0Xq5K

MD5加密是不可逆的。故数据已经很安全了,代码如下

MD5CryptoServiceProvider在命名空间:System.Security.Cryptography;

    #region =======MD5加密======
/// <summary>
/// MD5加密
/// </summary>
/// <param name="sDataIn"></param>
/// <returns></returns>
public static string GetMD5(string sDataIn)
{
MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
byte[] bytValue, bytHash;
bytValue = System.Text.Encoding.UTF8.GetBytes(sDataIn + "unity3d");
bytHash = md5.ComputeHash(bytValue);
md5.Clear();
string sTemp = "";
for (int i = ; i < bytHash.Length; i++)
{
sTemp += bytHash[i].ToString("X").PadLeft(, '');
}
return sTemp.ToLower();
}

当然,你可以把原始密码用MD5加密几次。这样是不是更加安全呢。

 /// <summary>
/// 登陆入口,用于密码加密,加密后的密码为: s+md5(s+md5(pwd))
/// </summary>
/// <param name="pwd">用户输入的密码或者数据库中存储的用户密码</param>
/// <param name="s">随机产生一个两位的字母:s,也可以自己指定字母</param>
/// <returns></returns>
public static string Entry(string pwd, string s)
{
if (string.IsNullOrEmpty(s))
{
Random randmon = new Random();
s = ((char)randmon.Next(, )).ToString() + ((char)randmon.Next(, )).ToString();
}
return s + GetMD5((s + GetMD5(pwd)));
}

然后直接调用Entry("unity3d","AB");即可。