关于C#使用sha256安全登录与注册

获取salt

第一种方法:通过随机数筛出64位无规则数字(包含数字,大写字母,小写字母)

public string GetSalt()
        {
            //定义salt;
            string salt = "";
            //随机数
            Random random = new Random();
            //确定位数64位
            for (int i = 0; i < 64; i++)
            {
            //定义每一个字符的类型(0为数字0-9,1为A-Z,2为a-z)
                int key = random.Next(3);
                switch (key)
                {
                    case 0:
                        int code1 = random.Next(10);
                        salt += code1;
                        break;
                    case 1:
                        char code2 = (char)(random.Next(26) + 65);
                        salt += code2;
                        break;
                    case 2:
                        char code3 = (char)(random.Next(26) + 97);
                        salt += code3;
                        break;
                }
            }
            return salt;
        }

第二种方法:通过Guid.NewGuid()来获取salt
通过该方法可以获取32位的小写字母和数字组合的数字
关于Guid.NewGuid()的介绍

public string GetSalt2()
{
	string salt2 = Guid.NewGuid().ToString("N");
	return salt2;
 }   
说明符返回值的格式
N32 位
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
D由连字符分隔的 32 位数字
xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
B括在大括号中、由连字符分隔的 32 位数字
{xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx}
P括在圆括号中、由连字符分隔的 32 位数字
(xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx)

第三种方法:通过RNGCryptoServiceProvider()方法获取salt
参考:C#使用 RNGCryptoServiceProvider 生成强随机字符串

private static RNGCryptoServiceProvider _random = new RNGCryptoServiceProvider();
public string GetSalt3()
{
   	return GetRandomString();
}
public string GetRandomString()
{
      //定义字母表
      string key = "QWERTYUIOPASDFGHJKLZXCVBNMqwertyuiopasdfghjklzxcvbnm1234567890";
      int length = key.Length;
      StringBuilder sb = new StringBuilder(length);
      //定义salt长度
      for (int i = 0; i < 64; i++)
      {
          sb.Append(key[SetRandomSeeds(length)]);
      }
      return sb.ToString();
}
public int SetRandomSeeds(int length)
{
      decimal maxValue = long.MaxValue;
      byte[] array = new byte[8];
      
      _random.GetBytes(array);

      return (int)(Math.Abs(BitConverter.ToInt64(array,0)) / maxValue * length);
}  

sha256非对称加密

public string GetSha256(string str)    
    {
    
        byte[] bytes = Encoding.UTF8.GetBytes(str):
        byte[] hash = SHA256Managed.Create().ComputeHash(bytes);

        StringBuilder builder1 = new StringBuilder();
        for (int i = 0; i < hash.Length; i++)
        {
            builder1.Append(hash[i].ToString("X2"));
        }

        return builder1.ToString();
    }

加密方式:

string salt = GetSalt();
string encrypted_password = GetSha256(GetSha256(pwd)+salt);

存入数据库

将用户名和加密后的密码(encrypted_password)存入user表中,salt单独存储至salt表,掌握它们的对应关系。

登录

点击登录按钮,获取窗体中用户名,并与数据库user表中用户名对应,若没有,返回“用户名或密码错误”,否则,查出对应 salt 值。并获取窗体中的密码(明文),让其以上述加密方式进行加密得到的值与数据库中user表中的(encrypted_password)对照,错误返回“用户名或密码错误”,正确则登录成功。

C#中,可以使用SHA256算法进行哈希加密。引用提供了一个使用SHA256的小例子。首先,需要引入System.Security.Cryptography命名空间。然后,可以使用SHA256.Create()创建一个SHA256实例。接下来,通过调用ComputeHash方法,将要加密的数据转换为字节数组,并计算其哈希值。最后,可以通过Convert.ToBase64String将字节数组转换为字符串表示的哈希值。引用中的代码示例展示了如何使用salt和密码来计算密码的哈希值。首先,通过将密码与salt进行拼接,得到经过盐值计算的密码。然后,使用SHA256算法对该密码进行哈希计算,并返回计算完成的哈希值。引用中的代码示例展示了如何在注册用户时使用SHA256进行密码的哈希加密。首先,使用RandomNumberGenerator.Create()生成一个加密随机数生成器。然后,通过调用GetBytes方法将生成的随机数转换为字节数组。接下来,将随机数转换为字符串形式的salt。通过调用SaltAndHashPwd方法,将密码和salt作为参数,计算出密码的哈希值。最后,可以将用户名、saltsaltedhashPwd保存在用户对象中,并将用户对象添加到用户列表中。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [C#使用SHA256哈希算法实现简单用户注册与验证](https://blog.csdn.net/mr_along/article/details/126432294)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值