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);
    }
}
相关推荐
唐青枫6 小时前
C#.NET 定时任务与队列利器:Hangfire 完整教程
c#·.net
hez201012 小时前
Runtime Async - 步入高性能异步时代
c#·.net·.net core·clr
mudtools1 天前
.NET驾驭Word之力:玩转文本与格式
c#·.net
唐青枫1 天前
C#.NET 数据库开发提速秘籍:SqlSugar 实战详解
c#·.net
mudtools2 天前
.NET驾驭Word之力:理解Word对象模型核心 (Application, Document, Range)
c#·.net
侃侃_天下2 天前
最终的信号类
开发语言·c++·算法
echoarts2 天前
Rayon Rust中的数据并行库入门教程
开发语言·其他·算法·rust
Aomnitrix2 天前
知识管理新范式——cpolar+Wiki.js打造企业级分布式知识库
开发语言·javascript·分布式
大飞pkz2 天前
【设计模式】C#反射实现抽象工厂模式
设计模式·c#·抽象工厂模式·c#反射·c#反射实现抽象工厂模式
每天回答3个问题2 天前
UE5C++编译遇到MSB3073
开发语言·c++·ue5