C# 中使用Hash用于密码加密

通过一定的哈希算法(典型的有MD5,SHA-1等),将一段较长的数据映射为较短小的数据,这段小数据就是大数据的哈希值。他最大的特点就是唯一性,一旦大数据发生了变化,哪怕是一个微小的变化,他的哈希值也会发生变化。类似于DNA,既然是DNA,那就保证了没有两个数据的哈希值是完全相同的。

哈希值的作用:哈希值,即HASH值,是通过对文件内容进行加密运算得到的一组二进制值,主要用途是用于文件校验或签名。正是因为这样的特点,它常常用来判断两个文件是否相同。

比如,从网络上下载某个文件,只要把这个文件原来的哈希值同下载后得到的文件的哈希值进行对比,如果相同则表示两个文件完全一致,下载过程没有损坏文件。而如果不一致,则表明下载得到的文件跟原来的文件不同,文件在下载过程中受到了损坏。

csharp 复制代码
using System.Security.Cryptography;
using System.Text;

namespace WebApplicationPwd;

public static class PasswordHelper
{
    public static string Encryption(string pwd, string? salt)
    {
        if (string.IsNullOrEmpty(salt))
        {
            var pwdBytes = Encoding.ASCII.GetBytes(pwd);
            var pwdHashBytes = MD5.HashData(pwdBytes);
            return Convert.ToBase64String(pwdHashBytes);
        }
        else
        {
            //var pwdBytes = Encoding.ASCII.GetBytes(pwd + salt);
            //var pwdHash256Bytes = SHA256.HashData(pwdBytes);
            //return Convert.ToBase64String(pwdHash256Bytes);


            #region PBKDF2+salt
            var saltBytes = Encoding.ASCII.GetBytes(salt);
            using var pkdf2 = new Rfc2898DeriveBytes(pwd, saltBytes, 1000);
            var pwdHashRfcBytes = pkdf2.GetBytes(32);
            return Convert.ToBase64String(pwdHashRfcBytes);
            #endregion

            #region Bcrypt  & Argon2  不需要加盐   
            //   <PackageReference Include="BCrypt.Net-Next" Version="4.0.3" />

            //return BCrypt.Net.BCrypt.HashPassword(pwd);
            #endregion
        }
    }


    public static bool VerifyPassword(string pwd, string hashPwd, string salt)
    {
        return Encryption(pwd, salt) == hashPwd;
    }

    public static string CreateSalt()
    {
        var randomNu = RandomNumberGenerator.GetBytes(32);
        return Convert.ToBase64String(randomNu);
    }
}
相关推荐
测试员周周21 小时前
【AI测试功能3】AI功能测试的三层架构:单元测试 → 集成测试 → E2E测试——AI系统测试金字塔实战指南
开发语言·人工智能·python·功能测试·架构·单元测试·集成测试
lly20240621 小时前
AppML 案例原型
开发语言
jllllyuz21 小时前
MATLAB 回声抵消(AEC)、噪声抑制(NS)、自动增益控制(AGC)完整实现
开发语言·matlab
froginwe1121 小时前
Vue.js 计算属性
开发语言
05候补工程师21 小时前
【408 从零到一】线性表逻辑特征、存储结构对比与 C/C++ 动态内存分配避坑指南
c语言·开发语言·数据结构·c++·考研
yongui4783421 小时前
MATLAB 使用遗传算法求解微电网优化配置数学模型
开发语言·matlab
郝学胜-神的一滴21 小时前
Python 抽象基类深度解析:从简易模拟到 abc 模块的优雅实践
开发语言·python·pycharm
Python伍六七1 天前
给予Python开发的【16款高效办公自动化工具合集】,告别低效加班!
开发语言·python·自动化
rit84324991 天前
基于博弈论的小区分簇算法MATLAB实现
开发语言·算法·matlab
怕什么真理无穷1 天前
C++面试5_ TCP 粘包2(工业级)
开发语言·c++·tcp/ip