SHA1哈希算法是一個用來進行數字簽名的算法,對于長度小于2^64位的消息,SHA1會產生一個160位的消息摘要,這個消息摘要可以用來驗證數據的完整性。SHA1有一些特性,一是不可以從消息摘要中復原信息,另外一個就是不同的消息會產生不同的消息摘要。所以如果在傳輸的過程中,數據發生了丟失或者損壞,通過消息摘要就可以看出來。
在.NET中對程序集進行強簽名的時候,需要生成一個公鑰,通過公鑰生成一個公鑰標記的時候也會用到SHA1算法。這個算法的具體原理,可以在網上找到,這里介紹一下用.NET提供的類庫來使用這個算法。主要有四種使用方式。
1.通過SHA1CryptoServiceProvider
System.Security.Cryptography.SHA1 sha = new System.Security.Cryptography.SHA1CryptoServiceProvider();
//strSource為傳入的字符串,字節數組為加密后的
byte[] bytResult = sha.ComputeHash(System.Text.Encoding.Default.GetBytes(strSource));
2.通過SHA1類
System.Security.Cryptography.SHA1 sha = System.Security.Cryptography.SHA1.Create();
//注意編碼UTF8、UTF7、Unicode等的選擇
byte[] bytResult = sha.ComputeHash(System.Text.Encoding.UTF8.GetBytes(strSource));
3.通過HashPasswordForStoringInConfigFile方法
return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "SHA1");
4.使用SHA1Managed
SHA1Managed sha = new SHA1Managed();
byte[] bytResult = sha.ComputeHash(strSource);
四種方法生成的結果都一樣,唯一需要注意的就是傳入的字符串的編碼。