在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存用户密码(应选
BCrypt、Argon2或Rfc2898DeriveBytes) - 需要加盐(salt)时,把盐和原字符串拼接后再哈希,不要单独哈希盐
- .NET 6+ 支持
HashAlgorithm.TryComputeHash,性能略优,但日常用ComputeHash足够
基本上就这些。用对编码、选对API、理解适用场景,MD5计算在C#里不复杂但容易忽略细节。










