MD5的使用

    MD5的全称是Message-Digest Algorithm 5(信息-摘要算法),在90年代初由Mit Laboratory for Computer Science和Rsa data security inc的Ronald l. rivest开发出来,经md2、md3和md4发展而来。它的作用是让大容量信息在用数字签名软件签署私人密匙前被"压缩"成一种保密的格式(就是把一个任意长度的字节串变换成一定长的大整数).不管是md2、md4还是md5,它们都需要获得一个随机长度的信息并产生一个128位的信息摘要.
    MD5 算法的哈希值大小为 128 位。是一种不可逆的算法。

    与MD5 相关:
System.Security.Cryptography.MD5
System.Security.Cryptography.MD5CryptoServiceProvider()
System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5")

    例子: 
    /// <summary>
    ///方法一:通过使用 new 运算符创建对象
    
/// </summary>
     /// <param name="strSource">需要加密的明文</param>

     /// <returns>返回16位加密结果,该结果取32位加密结果的第9位到25位</returns>
    public string Get_MD5_Method1(string strSource)
     {
       
   //new
        System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();

        //获取密文字节数组
        byte[] bytResult = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(strSource));

        //转换成字符串,并取9到25位
        string strResult = BitConverter.ToString(bytResult, 4, 8);

        //转换成字符串,32位

        //string strResult = BitConverter.ToString(bytResult);
        //BitConverter转换出来的字符串会在每个字符中间产生一个分隔符,需要去除掉
        strResult = strResult.Replace("-", "");

         return strResult;
    }

        ///<summary>
        ///
方法二:通过调用特定加密算法的抽象类上的Create 方法,创建实现特定加密算法的对象。
        ///</summary>
        ///<param name="strSource">需要加密的明文</param>
        ///<returns>返回位加密结果
</returns>
        public string Get_MD5_Method2(string strSource)
        {
            string strResult = "";
            //Create
            System.Security.Cryptography.MD5 md5 = System.Security.Cryptography.MD5.Create();

            //注意编码UTF8、UTF7、Unicode等的选择 
            byte[] bytResult = md5.ComputeHash(System.Text.Encoding.UTF8.GetBytes(strSource));

            //字节类型的数组转换为字符串
            for (int i = 0; i < bytResult.Length; i++)
            { 
                //16
进制转换
                strResult = strResult + bytResult[i].ToString("X");
            }

            return strResult;
        }

        ///<summary>
        ///方法三:直接使用HashPasswordForStoringInConfigFile生成
        ///</summary>
        ///<param name="strSource">需要加密的明文</param>
        ///<returns>返回位加密结果
</returns>
        public string Get_MD5_Method3(string strSource)
        {
            return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5");
        }

posted @ 2008-03-24 13:02  天秤水  阅读(3001)  评论(0编辑  收藏  举报