相关疑难解决方法(0)

ASP.NET成员资格使用的默认哈希算法是什么?

ASP.NET成员资格使用的默认哈希算法是什么?我怎么能改变它?

membership asp.net authentication hash

54
推荐指数
4
解决办法
7万
查看次数

在Ruby中重新实现ASP.NET成员资格和用户密码哈希

我有一个庞大的用户数据库(~200,000),我正在从ASP.NET应用程序转移到Ruby on Rails应用程序.我真的不想要求每个用户重置密码,所以我试图在Ruby中重新实现C#密码散列函数.

旧功能是这样的:

public string EncodePassword(string pass, string saltBase64)
 {
     byte[] bytes = Encoding.Unicode.GetBytes(pass);
     byte[] src = Convert.FromBase64String(saltBase64);
     byte[] dst = new byte[src.Length + bytes.Length];
     Buffer.BlockCopy(src, 0, dst, 0, src.Length);
     Buffer.BlockCopy(bytes, 0, dst, src.Length, bytes.Length);
     HashAlgorithm algorithm = HashAlgorithm.Create("SHA1");
     byte[] inArray = algorithm.ComputeHash(dst);
     return Convert.ToBase64String(inArray);
 }
Run Code Online (Sandbox Code Playgroud)

示例哈希密码和盐是(并且使用的密码是"密码"):

哈希密码:"weEWx4rhyPtd3kec7usysxf7kpk ="盐:"1ptFxHq7ALe7yXIQDdzQ9Q =="密码:"密码"

现在使用以下Ruby代码:

require "base64"
require "digest/sha1"


password = "password"
salt = "1ptFxHq7ALe7yXIQDdzQ9Q=="

concat = salt+password

sha1 = Digest::SHA1.digest(concat)

encoded = Base64.encode64(sha1)

puts encoded
Run Code Online (Sandbox Code Playgroud)

我没有得到正确的密码哈希(我得到"+ BsdIOBN/Vh2U7qWG4e + O13h3iQ ="而不是"weEWx4rhyPtd3kec7usysxf7kpk =").任何人都可以看到问题可能是什么?

非常感谢 …

ruby asp.net base64 sha1 ruby-on-rails

8
推荐指数
1
解决办法
5976
查看次数

标签 统计

asp.net ×2

authentication ×1

base64 ×1

hash ×1

membership ×1

ruby ×1

ruby-on-rails ×1

sha1 ×1