zoukankan      html  css  js  c++  java
  • 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);
    }

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

    转自:http://www.cnblogs.com/anjou/archive/2008/08/05/1261290.html

    作者:chlyzone
    出处:http://www.cnblogs.com/chlyzone/
    欢迎转载,请在文章页面明显位置给出原文连接。
  • 相关阅读:
    [转载]vue中全局和局部引入批量组件方法
    [转]详解在vue-test-utils中mock全局对象
    [转]imageMagick 在nodejs中报错Error: spawn identify ENOENT的解决方案
    使用 dva 如何配置异步加载路由组件
    dva.js 上手
    [转]axios的兼容性处理
    【转】链接伪类(:hover)CSS背景图片有闪动BUG
    【转】 svn: Server sent unexpected return value (403 Forbidden) in response to CHECKOUT request for-解决方法
    vue 路由相同路径跳转报错
    新手小白第一次与后端联调
  • 原文地址:https://www.cnblogs.com/chlyzone/p/2021113.html
Copyright © 2011-2022 走看看