SHA1與MD5

SHA1的使用

SHA1的全稱是Secure Hash Algorithm(安全哈希算法)。加密哈希函數將任意長度的二進制字符串映射爲固定長度的小型二進制字符串。加密哈希函數有這樣一個屬性:在計算上不大可能找到散列爲相同的值的兩個不同的輸入;也就是說,兩組數據的哈希值僅在對應的數據也匹配時纔會匹配。數據的少量更改會在哈希值中產生不可預知的大量更改。所以你很難從加密後的文字中找到蛛絲馬跡。

SHA1 算法的哈希值大小爲 160 位。是一種不可逆的算法。

SHA1相關:

System.Security.Cryptography.SHA1
System.Security.Cryptography.SHA1CryptoServiceProvider()
System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "SHA1")


例子:

/// <summary>
      /// 方法一:通過使用 new 運算符創建對象
    /// <summary>
     /// <param name="strSource">需要加密的明文</param>
     /// <returns>返回16位加密結果,該結果取32位加密結果的第9位到25位</returns>
    public string Get_SHA_Method1(string strSource)
    {
      //new
        System.Security.Cryptography.SHA1 sha= new System.Security.Cryptography.SHA1CryptoServiceProvider();
        //獲取密文字節數組
       byte [] bytResult = sha.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>返回32位加密結果</returns>
    public string Get_SHA_Method2(string strSource)
    {
        string strResult = "";
        //Create
        System.Security.Cryptography.SHA1 sha = System.Security.Cryptography.SHA1.Create();
        //注意編碼UTF8、UTF7、Unicode等的選擇 
        byte[] bytResult = sha.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>返回32位加密結果</returns>
    public string Get_SHA_Method3(string strSource)
    {
        return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "SHA1");
    }


 

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");  //只有對數字加密時會缺少位數
                strResult = strResult + bytResult[i].ToString("X2"); //這樣可以解決 
               strResult = strResult + bytResult[i].ToString("X").PadLeft(2,'0'); //這種方法也可以解決 PadLeft的意思是在字符串的左邊添加空格,使字符串達到指定的長度。PadRight是在字符串的右側加空格。
            }
            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");
        }


 轉自:http://blog.csdn.net/fogle/article/details/5688463

 

自己的一點補充:網上看到說SHA1比MD5安全性要好,但性能卻較MD5差。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章