Це дуже просто за допомогою System.Security.Cryptography.MD5 :
using (var md5 = MD5.Create())
{
using (var stream = File.OpenRead(filename))
{
return md5.ComputeHash(stream);
}
}
(Я вважаю, що реально використану реалізацію MD5 не потрібно утилізувати, але я, мабуть, все одно це роблю.)
Як ви порівнюєте результати після цього, залежить від вас; ви можете, наприклад, перетворити масив байтів у base64 або порівняти байти безпосередньо. (Пам'ятайте лише про те, що масиви не перекривають Equals
. Використовувати base64 - це простіше правильно, але трохи менш ефективно, якщо вас дійсно цікавить лише порівняння хешей.)
Якщо вам потрібно представити хеш як рядок, ви можете перетворити його в шістнадцятковий за допомогою BitConverter
:
static string CalculateMD5(string filename)
{
using (var md5 = MD5.Create())
{
using (var stream = File.OpenRead(filename))
{
var hash = md5.ComputeHash(stream);
return BitConverter.ToString(hash).Replace("-", "").ToLowerInvariant();
}
}
}