MD5 是 Message Digest Algorithm 5(資訊摘要演算法)的縮寫,MD5 一種散列(Hash)技術,廣泛用於加密、解密、資料簽名和資料完整性校正等方面。任何一個檔案,無論是可執行程式、影像檔、臨時檔案或者其他任何類型的檔案,也不管它體積多大,都可以計算出一個MD5值,如果檔案被修改過,就算只改動了一個位元組,其 MD5 值也會變得完全不同。因此,我們可以通過對比同一檔案的 MD5 值,來校正這個檔案是否被“篡改”過。
C# 可以方便的計算出檔案的 MD5 值:
計算檔案的MD5值
/// <summary>
/// 計算檔案的 MD5 值
/// </summary>
/// <param name="fileName">要計算 MD5 值的檔案名稱和路徑</param>
/// <returns>MD5 值16進位字串</returns>
public static string MD5File(string fileName)
{
return HashFile(fileName, "md5");
}
/// <summary>
/// 計算檔案的雜湊值
/// </summary>
/// <param name="fileName">要計算雜湊值的檔案名稱和路徑</param>
/// <param name="algName">演算法:sha1,md5</param>
/// <returns>雜湊值16進位字串</returns>
public static string HashFile(string fileName, string algName)
{
if (!System.IO.File.Exists(fileName))
return string.Empty;
FileStream fs = new FileStream(fileName, FileMode.Open, FileAccess.Read);
byte[] hashBytes = HashData(fs, algName);
fs.Close();
return ByteArrayToHexString(hashBytes);
}
/// <summary>
/// 計算雜湊值
/// </summary>
/// <param name="stream">要計算雜湊值的 Stream</param>
/// <param name="algName">演算法:sha1,md5</param>
/// <returns>雜湊值位元組數組</returns>
public static byte[] HashData(Stream stream, string algName)
{
HashAlgorithm algorithm;
if (algName == null)
{
throw new ArgumentNullException("algName 不能為 null");
}
if (string.Compare(algName, "sha1", true) == 0)
{
algorithm = SHA1.Create();
}
else
{
if (string.Compare(algName, "md5", true) != 0)
{
throw new Exception("algName 只能使用 sha1 或 md5");
}
algorithm = MD5.Create();
}
return algorithm.ComputeHash(stream);
}
ComputeHash 方法返回的是雜湊值位元組數組,而檔案的 MD5 值通常是用16進位的字串表示,位元組數群組轉換為16進位表示的字串的方法在 System.Web.Configuration.MachineKeySection 中已經提供了一個名為 ByteArrayToHexString 方法,但是該方法是 NonPublic 的,我們不能直接調用。這裡我們通過反射來調用 MachineKeySection 中的 ByteArrayToHexString 方法。
通過反射調用 MachineKeySection 中的 ByteArrayToHexString 方法:
通過反射調用 MachineKeySection 中的 ByteArrayToHexString 方法
/// <summary>
/// 位元組數群組轉換為16進位表示的字串
/// </summary>
public static string ByteArrayToHexString(byte[] buf)
{
int iLen = 0;
// 通過反射擷取 MachineKeySection 中的 ByteArrayToHexString 方法,該方法用於將位元組數群組轉換為16進位表示的字串。
Type type = typeof(System.Web.Configuration.MachineKeySection);
MethodInfo byteArrayToHexString = type.GetMethod("ByteArrayToHexString", BindingFlags.Static | BindingFlags.NonPublic);
// 位元組數群組轉換為16進位表示的字串
return (string)byteArrayToHexString.Invoke(null, new object[] { buf, iLen });
}
如今“MD5碰撞產生器”的出現,使 MD5 也正在面臨挑戰。
順便介紹一個 MD5 工具 Md5Checker,Md5Checker 是一款免費、快速、小巧、易用的檔案 MD5 值計算、驗證、管理軟體。Md5Checker 的官方網站是:http://cn.getmd5checker.com/