C#计算文件的MD5值实例

C#计算文件的MD5值实例

  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);

  }

欢迎进入.NET社区论坛,与200万技术人员互动交流 >>进入

  /// <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/

posted @ 2014-04-15 09:55  朱煜  阅读(2028)  评论(0编辑  收藏  举报