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

在C#中计算字符串的MD5值,核心是使用 System.Security.Cryptography 命名空间下的 MD5 类,将字符串转为字节数组后哈希,再转成十六进制字符串表示。
推荐用 MD5.Create()(而非已过时的 MD5CryptoServiceProvider),它更安全、跨平台兼容性好。
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,尤其处理中文时:
fc9d1f6b740c2944e2a2156e71224511
MD5是哈希算法,不是加密——不可逆,也不防碰撞。实际开发中要注意:
BCrypt、Argon2 或 Rfc2898DeriveBytes)HashAlgorithm.TryComputeHash,性能略优,但日常用 ComputeHash 足够基本上就这些。用对编码、选对API、理解适用场景,MD5计算在C#里不复杂但容易忽略细节。
以上就是C#怎么进行MD5加密 C#计算字符串MD5值方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号