.NET 9.0 的 Blazor Web App 项目中 Hash 变换(MD5、Pbkdf2) 使用备忘

一、生成 string 对应的 MD5 码

cs 复制代码
    /// <summary>
    /// 生成 string 对应的 MD5 码
    /// </summary>
    /// <param name="str">需要转换的字符串 string:用于登录认证时,str = username + 线下传递的key + DateTime.Now.Ticks.ToString() </param>
    /// <returns>转换后的 MD5 码</returns>
    public static string GetMD5FromString(string str)
    {
        byte[] data = System.Security.Cryptography.MD5.HashData(System.Text.Encoding.UTF8.GetBytes(str));
        System.Text.StringBuilder sBuilder = new();
        for (int i = 0; i < data.Length; i++)
        {
            sBuilder.Append(data[i].ToString("x2"));
        }

        return sBuilder.ToString().ToUpper();
    }

二、 生成 string 对应的 Pbkdf2 码

cs 复制代码
    /// <summary>
    /// derive a 256-bit subkey (use HMACSHA256 with 100 iterations)
    /// </summary>
    /// <param name="str">需要转换的字符串 string:用于登录认证时,通常为 username</param>
    /// <param name="password">线下传递的key</param>
    /// <param name="Ticks">用于登录认证时,通常为 DateTime.Now.Ticks.ToString(),用于检测登录认证是否超时</param>
    /// <returns>转换后的 Pbkdf2 码</returns>
    public static string GetPbkdf2FromString(string str, string password, string Ticks)
    {
        string hashed = Convert.ToBase64String(Microsoft.AspNetCore.Cryptography.KeyDerivation.KeyDerivation.Pbkdf2(
            password: password,
            salt: System.Text.Encoding.UTF8.GetBytes(str + Ticks),
            prf: Microsoft.AspNetCore.Cryptography.KeyDerivation.KeyDerivationPrf.HMACSHA256,
            iterationCount: 100,
            numBytesRequested: 256 / 8));

        return hashed;
    }
相关推荐
玩c#的小杜同学21 分钟前
工业级稳定性:如何利用生产者-消费者模型(BlockingCollection)解决串口/网口高频丢包问题?
笔记·学习·性能优化·c#·软件工程
游乐码3 小时前
c#结构体
开发语言·c#
bugcome_com5 小时前
# C# 变量作用域详解
开发语言·c#
三方测试小学徒6 小时前
GB/T 34946-2017《C#语言源代码漏洞测试规范》之整体解读
c#·cma·cnas·34946
光泽雨7 小时前
P/Invok执行时的搜索顺序
c#
用户298698530147 小时前
C# Word自动化:轻松插入特殊符号,告别手动烦恼!
后端·c#·.net
光泽雨7 小时前
C#库文件调用逻辑
开发语言·c#
步步为营DotNet8 小时前
深入剖析.NET中Span:零拷贝内存操作的基石
服务器·php·.net
kylezhao20199 小时前
C# 中的类型转换详解
c#