C#信息摘要算法(MD5)

MD5 是 Message Digest Algorithm 5(信息摘要算法)的缩写,MD5 一种散列(Hash)技术,广泛用于加密、解密、数据签名和数据完整性校验等方面。任何一个文件,无论是可执行程序、图像文件、临时文件或者其他任何类型的文件,也不管它体积多大,都可以计算出一个MD5值,如果文件被修改过,就算只改动了一个字节,其 MD5 值也会变得完全不同。因此,我们可以通过对比同一文件的 MD5 值,来校验这个文件是否被“篡改”过。

C# 可以方便的计算出文件的 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 方法:

/// <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(nullnew object[] { buf, iLen });
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值