MVC 5.2.2.0 中使用的 UserManager.CreateAsync 默认哈希

Bre*_*tKB 2 asp.net-mvc hash asp.net-mvc-5

执行时密码是否经过哈希处理?UserManager.CreateAsync(user, model.Password);。如果是这样,MVC 5 版本 5.2.2.0 项目中的哈希默认情况下是如何完成的?还是SHA1+salt+base64吗?类似的东西?:

internal string EncodePassword(string pass,  string salt)
{
   byte[] bytes = Encoding.Unicode.GetBytes(pass);
   byte[] src = Convert.FromBase64String(salt);
   byte[] dst = new byte[src.Length + bytes.Length];
   byte[] inArray = null;
   Buffer.BlockCopy(src, 0, dst, 0, src.Length);
   Buffer.BlockCopy(bytes, 0, dst, src.Length, bytes.Length);

   HashAlgorithm algorithm = HashAlgorithm.Create("SHA1");
   inArray = algorithm.ComputeHash(dst);

   return Convert.ToBase64String(inArray);
}
Run Code Online (Sandbox Code Playgroud)

dfo*_*tun 5

这就是密码哈希方法。

    public string HashPassword(string password)
    {
        byte[] salt;
        byte[] buffer2;
        if (password == null)
        {
            throw new ArgumentNullException("password");
        }
        using (Rfc2898DeriveBytes bytes = new Rfc2898DeriveBytes(password, 0x10, 0x3e8))
        {
            salt = bytes.Salt;
            buffer2 = bytes.GetBytes(0x20);
        }
        byte[] dst = new byte[0x31];
        Buffer.BlockCopy(salt, 0, dst, 1, 0x10);
        Buffer.BlockCopy(buffer2, 0, dst, 0x11, 0x20);
        return Convert.ToBase64String(dst);
    }
Run Code Online (Sandbox Code Playgroud)