C# sha1加密
阿新 • • 發佈:2018-12-30
安全雜湊演算法(Secure Hash Algorithm)主要適用於數字簽名標準 (Digital Signature Standard DSS)裡面定義的數字簽名演算法(Digital Signature Algorithm DSA)。對於長度小於2^64位的訊息,SHA1會產生一個160位的訊息摘要。當接收到訊息的時候,這個訊息摘要可以用來驗證資料的完整性。在傳輸的過程中,資料很可能會發生變化,那麼這時候就會產生不同的訊息摘要。 SHA1有如下特性:不可以從訊息摘要中復原資訊;兩個不同的訊息不會產生同樣的訊息摘要,(但會有1x10 ^ 48分之一的機率出現相同的訊息摘要,一般使用時忽略)。
程式碼例項:
/// <summary> /// SHA1 加密,返回大寫字串 /// </summary> /// <param name="content">需要加密字串</param> /// <returns>返回40位UTF8 大寫</returns> public static string SHA1(string content) { return SHA1(content, Encoding.UTF8); } /// <summary> /// SHA1 加密,返回大寫字串 /// </summary> /// <param name="content">需要加密字串</param> /// <param name="encode">指定加密編碼</param> /// <returns>返回40位大寫字串</returns> public static string SHA1(string content, Encoding encode) { try { SHA1 sha1 = new SHA1CryptoServiceProvider(); byte[] bytes_in = encode.GetBytes(content); byte[] bytes_out = sha1.ComputeHash(bytes_in); sha1.Dispose(); string result = BitConverter.ToString(bytes_out); result = result.Replace("-", ""); return result; } catch (Exception ex) { throw new Exception("SHA1加密出錯:" + ex.Message); } }
C# MD5 加密:http://blog.csdn.net/u011127019/article/details/51384246