【加密算法】MD5

一、简介

MD5的全称是Message-Digest Algorithm 5(信息摘要算法),在90年代初由MIT Laboratory for Computer Science和RSA Data Security Inc的Ronald L. Rivest开发出来,经MD2、MD3和MD4发展而来。

消息摘要算法的主要特征是加密过程不需要密钥,并且经过加密的数据无法被解密,只有输入相同的明文数据经过相同的消息摘要算法才能得到相同的密文。消息摘要算法不存在密钥的管理与分发问题,适合于分布式网络上使用。由于其加密计算的工作量相当可观,所以以前的这种算法通常只用于数据量有限的情况下的加密,例如计算机的口令就是用不可逆加密算法加密的。近年来,随着计算机性能的飞速改善,加密速度不再成为限制这种加密技术发展的桎梏,因而消息摘要算法应用的领域不断增加。

二、实现

/// <summary>
/// MD5加密类
/// </summary>
public class Md5Helper
{
    /// <summary>
    /// MD5加密
    /// 加权:无
    /// 位数:32位
    /// </summary>
    /// <param name="plaintext">明文</param>
    /// <returns>返回32位的密文</returns>
    public static string Encrypt(string plaintext)
    {
        return Encrypt(plaintext, true, null);
    }

    /// <summary>
    /// MD5加密
    /// 加权:有
    /// 位数:32位
    /// </summary>
    /// <param name="plaintext">明文</param>
    /// <param name="salt">随机字符串</param>
    /// <returns>返回32位的密文</returns>
    public static string Encrypt(string plaintext, string salt)
    {
        return Encrypt(plaintext, true, salt);
    }

    /// <summary>
    /// MD5加密
    /// 加权:无
    /// 位数:32位或16位
    /// </summary>
    /// <param name="plaintext">明文</param>
    /// <param name="isThirtyTwo">是 返回32位,否返回16位</param>
    /// <returns></returns>
    public static string Encrypt(string plaintext, bool isThirtyTwo)
    {
        return Encrypt(plaintext, isThirtyTwo, null);
    }

    /// <summary>
    /// MD5加密
    /// 加权:有
    /// 位数:32位或16位
    /// </summary>
    /// <param name="plaintext"></param>
    /// <param name="isThirtyTwo"></param>
    /// <param name="salt"></param>
    /// <returns></returns>
    public static string Encrypt(string plaintext, bool isThirtyTwo, string salt)
    {
        if (String.IsNullOrEmpty(plaintext))
        {
            throw new ArgumentNullException("明文不能为空");
        }

        if (!String.IsNullOrEmpty(salt))
        {
            plaintext = plaintext + salt; //加权是为了增加密文的复杂性。 这里的加权位置可按照自己的需要任意调整
        }

        MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
        byte[] bytResult = md5.ComputeHash(Encoding.UTF8.GetBytes(plaintext));
        md5.Clear();

        string result = String.Empty;
        if (isThirtyTwo)
        {
            result = BitConverter.ToString(bytResult);
        }
        else
        {
            result = BitConverter.ToString(bytResult, 4, 8);
        }
        return result.Replace("-", "");
    }
}
posted @ 2018-12-11 16:16  a boy  阅读(207)  评论(0编辑  收藏  举报