C#怎么进行MD5加密 C#计算字符串MD5值方法

在C#中计算字符串MD5值应使用MD5.Create()获取实例,以UTF8编码转字节数组,调用ComputeHash()后用BitConverter.ToString()转十六进制并移除短横线转小写;注意MD5仅适用于校验或兼容场景,不可用于密码存储。

在C#中计算字符串的MD5值,核心是使用 System.Security.Cryptography 命名空间下的 MD5 类,将字符串转为字节数组后哈希,再转成十六进制字符串表示。

使用MD5.Create()获取实例并计算

推荐用 MD5.Create()(而非已过时的 MD5CryptoServiceProvider),它更安全、跨平台兼容性好。

  • 先用指定编码(如UTF8)把字符串转成字节数组
  • 调用 ComputeHash() 得到哈希字节数组
  • BitConverter.ToString() 转成大写十六进制字符串,再去掉短横线

一行代码封装常用方法

可封装成静态方法,方便复用:

(注意:MD5不适用于密码存储,仅适合校验或兼容旧系统)

public static string GetMD5(string input)
{
    using var md5 = MD5.Create();
    var bytes = Encoding.UTF8.GetBytes(input);
    var hash = md5.ComputeHash(bytes);
    return BitConverter.ToString(hash).Replace("-", "").ToLower();
}

注意编码一致性

不同编码(如UTF8 vs GB2312)会导致结果不同,务必统一用 Encoding.UTF8,尤其处理中文时:

  • “你好”用UTF8编码 → 正确MD5值:fc9d1f6b740c2944e2a2156e71224511
  • 若误用ASCII编码 → 中文会变问号,结果完全错误

避免常见坑

MD5是哈希算法,不是加密——不可逆,也不防碰撞。实际开发中要注意:

  • 别用MD5存用户密码(应选 BCryptArgon2Rfc2898DeriveBytes
  • 需要加盐(salt)时,把盐和原字符串拼接后再哈希,不要单独哈希盐
  • .NET 6+ 支持 HashAlgorithm.TryComputeHash,性能略优,但日常用 ComputeHash 足够

基本上就这些。用对编码、选对API、理解适用场景,MD5计算在C#里不复杂但容易忽略细节。