MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。
MD5的用途主要有:
一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出
新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。
数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。
密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储
明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。
对于密码存储,Asp.net的实现方法为:
protected void Page_Load(object sender, EventArgs e) { string plainPassword = "innovator"; System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider(); System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding(); byte[] data = ascii.GetBytes(plainPassword); byte[] result = md5.ComputeHash(data); // Convert the MD5 result to Hexadecimal string string MD5Password = BinaryToHex(result); string aa = ""; }
private String BinaryToHex(byte[] BinaryArray) { string result = ""; long lowerByte; long upperByte; foreach (Byte singleByte in BinaryArray) { lowerByte = singleByte & 15; upperByte = singleByte >> 4; result += NumberToHex(upperByte); result += NumberToHex(lowerByte); } return result; }
private static char NumberToHex(long Number) { if (Number > 9) return Convert.ToChar(65 + (Number - 10)); else return Convert.ToChar(48 + Number); }