Aras学习笔记 (20) MD5加密方法介绍

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);
        }
原文地址:https://www.cnblogs.com/61007257Steven/p/10069300.html