SHA1哈希算法是一個(gè)用來(lái)進(jìn)行數(shù)字簽名的算法,對(duì)于長(zhǎng)度小于2^64位的消息,SHA1會(huì)產(chǎn)生一個(gè)160位的消息摘要,這個(gè)消息摘要可以用來(lái)驗(yàn)證數(shù)據(jù)的完整性。SHA1有一些特性,一是不可以從消息摘要中復(fù)原信息,另外一個(gè)就是不同的消息會(huì)產(chǎn)生不同的消息摘要。所以如果在傳輸?shù)倪^(guò)程中,數(shù)據(jù)發(fā)生了丟失或者損壞,通過(guò)消息摘要就可以看出來(lái)。
在.NET中對(duì)程序集進(jìn)行強(qiáng)簽名的時(shí)候,需要生成一個(gè)公鑰,通過(guò)公鑰生成一個(gè)公鑰標(biāo)記的時(shí)候也會(huì)用到SHA1算法。這個(gè)算法的具體原理,可以在網(wǎng)上找到,這里介紹一下用.NET提供的類庫(kù)來(lái)使用這個(gè)算法。主要有四種使用方式。
1.通過(guò)SHA1CryptoServiceProvider
System.Security.Cryptography.SHA1 sha = new System.Security.Cryptography.SHA1CryptoServiceProvider();
//strSource為傳入的字符串,字節(jié)數(shù)組為加密后的
byte[] bytResult = sha.ComputeHash(System.Text.Encoding.Default.GetBytes(strSource));
2.通過(guò)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.通過(guò)HashPasswordForStoringInConfigFile方法
return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "SHA1");
4.使用SHA1Managed
SHA1Managed sha = new SHA1Managed();
byte[] bytResult = sha.ComputeHash(strSource);
四種方法生成的結(jié)果都一樣,唯一需要注意的就是傳入的字符串的編碼。