【发布时间】:2009-02-09 22:52:00
【问题描述】:
我有一个庞大的用户数据库(约 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);
}
哈希密码和盐的示例是(并且使用的密码是“密码”):
散列密码:“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
我没有得到正确的密码哈希(我得到的是“+BsdIOBN/Vh2U7qWG4e+O13h3iQ=”而不是“weEWx4rhyPtd3kec7usysxf7kpk=”)。谁能看出问题出在哪里?
非常感谢
阿方
【问题讨论】:
标签: asp.net ruby-on-rails ruby base64 sha1