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

来源:这里教程网 时间:2026-02-21 17:34:49 作者:

在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#里不复杂但容易忽略细节。

相关推荐