C# 通用方法MD5计算

MD5信息摘要算法(英语:MD5 Message-Digest Algorithm),一种被广泛使用的密码散列函数,可以产生出一个128位(16字节)的散列值(hash value),用于确保信息传输完整一致。MD5由美国密码学家罗纳德·李维斯特(Ronald Linn Rivest)设计,于1992年公开,用以取代MD4算法。这套算法的程序在 RFC 1321 标准中被加以规范。1996年后该算法被证实存在弱点,可以被加以破解,对于需要高度安全性的数据,专家一般建议改用其他算法,如SHA-2。2004年,证实MD5算法无法防止碰撞(collision),因此不适用于安全性认证,如SSL公开密钥认证或是数字签名等用途。

MD5算法的原理可简要的叙述为:MD5码以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值。
总体流程如下图所示,每次的运算都由前一轮的128位结果值和当前的512bit值进行运算 。


using System.Security.Cryptography;

/// 
/// 取Hash字符串
/// 
/// 原文
/// 返回大写字符串
/// Hash字符串
public static string ComputeHash(string sourceText, bool toUpper)
{
    if (sourceText == null)
        return null;

    StringBuilder result = new StringBuilder();
    using (MD5 md5 = new MD5CryptoServiceProvider())
    {
        byte[] data = md5.ComputeHash(Encoding.UTF8.GetBytes(sourceText));
        if (toUpper)
            for (int i = 0; i < data.Length; i++)
                result.Append(data[i].ToString("X2"));
        else
            for (int i = 0; i < data.Length; i++)
                result.Append(data[i].ToString("x2"));
    }

    return result.ToString();
}

/// 
/// 取Hash字符串
/// 
/// 待加密数据字节结合
/// 
/// 
public static string ComputeHash(byte[] data, bool toUpper)
{
    if (data == null)
        return string.Empty;
    StringBuilder result = new StringBuilder();
    using (MD5 md5 = new MD5CryptoServiceProvider())
    {
        if (toUpper)
            for (int i = 0; i < data.Length; i++)
                result.Append(data[i].ToString("X2"));
        else
            for (int i = 0; i < data.Length; i++)
                result.Append(data[i].ToString("x2"));
    }

    return result.ToString();

}

你可能感兴趣的:(c#,MD5加密,c#,哈希算法,MD5)