在C#中,數據的Hash以MD5或SHA-1的方式實現,MD5與SHA1都是Hash演算法,MD5輸出是128位的,SHA1輸出是160位的,MD5比SHA1快,SHA1比MD5強度高。 MD5與SHA1的比較: 1)對強行攻擊的安全性:最顯著和最重要的區別是SHA-1摘要比MD5摘要長32 位。使用 ...
在C#中,數據的Hash以MD5或SHA-1的方式實現,MD5與SHA1都是Hash演算法,MD5輸出是128位的,SHA1輸出是160位的,MD5比SHA1快,SHA1比MD5強度高。
MD5與SHA1的比較:
1)對強行攻擊的安全性:最顯著和最重要的區別是SHA-1摘要比MD5摘要長32 位。使用強行技術,產生任何一個報文使其摘要等於給定報摘要的難度對MD5是2^128數量級的操作,而對SHA-1則是2^160數量級的操作。這樣,SHA-1對強行攻擊有更大的強度。
2)對密碼分析的安全性:由於MD5的設計,易受密碼分析的攻擊,SHA-1顯得不易受這樣的攻擊。
3)速度:在相同的硬體上,SHA-1的運行速度比MD5慢。
SHA-1和MD5在C#中的實現:
1 public class HashHelper 2 { 3 /// <summary> 4 /// 計算文件的 MD5 值 5 /// </summary> 6 /// <param name="fileName">要計算 MD5 值的文件名和路徑</param> 7 /// <returns>MD5 值16進位字元串</returns> 8 public static string MD5File(string fileName) 9 { 10 return HashFile(fileName, "md5"); 11 } 12 13 /// <summary> 14 /// 計算文件的 sha1 值 15 /// </summary> 16 /// <param name="fileName">要計算 sha1 值的文件名和路徑</param> 17 /// <returns>sha1 值16進位字元串</returns> 18 public static string SHA1File(string fileName) 19 { 20 return HashFile(fileName, "sha1"); 21 } 22 23 /// <summary> 24 /// 計算文件的哈希值 25 /// </summary> 26 /// <param name="fileName">要計算哈希值的文件名和路徑</param> 27 /// <param name="algName">演算法:sha1,md5</param> 28 /// <returns>哈希值16進位字元串</returns> 29 private static string HashFile(string fileName, string algName) 30 { 31 if (!System.IO.File.Exists(fileName)) 32 { 33 return string.Empty; 34 } 35 36 System.IO.FileStream fs = new System.IO.FileStream(fileName, System.IO.FileMode.Open, System.IO.FileAccess.Read); 37 byte[] hashBytes = HashData(fs, algName); 38 fs.Close(); 39 return ByteArrayToHexString(hashBytes); 40 } 41 42 /// <summary> 43 /// 計算哈希值 44 /// </summary> 45 /// <param name="stream">要計算哈希值的 Stream</param> 46 /// <param name="algName">演算法:sha1,md5</param> 47 /// <returns>哈希值位元組數組</returns> 48 private static byte[] HashData(System.IO.Stream stream, string algName) 49 { 50 System.Security.Cryptography.HashAlgorithm algorithm; 51 if (algName == null) 52 { 53 throw new ArgumentNullException("algName 不能為 null"); 54 } 55 56 if (string.Compare(algName, "sha1", true) == 0) 57 { 58 algorithm = System.Security.Cryptography.SHA1.Create(); 59 } 60 else 61 { 62 if (string.Compare(algName, "md5", true) != 0) 63 { 64 throw new Exception("algName 只能使用 sha1 或 md5"); 65 } 66 algorithm = System.Security.Cryptography.MD5.Create(); 67 } 68 69 return algorithm.ComputeHash(stream); 70 } 71 72 /// <summary> 73 /// 位元組數組轉換為16進位表示的字元串 74 /// </summary> 75 private static string ByteArrayToHexString(byte[] buf) 76 { 77 return BitConverter.ToString(buf).Replace("-", ""); 78 } 79 }
參考:http://blog.rdiframework.net/article/222