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/
    欢迎转载,请在文章页面明显位置给出原文连接。
  • 相关阅读:
    描述一下Spring Bean的生命周期
    BeanFactory和ApplicationContext有什么区别
    谈谈你对AOP的理解
    谈谈对IOC的理解
    线程池中线程复用原理
    线程池中阻塞队列的最用?为什么是先添加队列而不是先创建最大线程
    为什么使用线程池?解释下线程池参数
    去噪声论文阅读
    怎么使用有三AI完成系统性学习
    JavaCnn项目注解
  • 原文地址:https://www.cnblogs.com/chlyzone/p/2021113.html
Copyright © 2011-2022 走看看