У меня есть большая база данных пользователей (~ 200 000), которую я перевожу из приложения ASP.NET в приложение Ruby on Rails. Я не хочу просить каждого пользователя сбросить свой пароль, и поэтому я пытаюсь повторно реализовать функцию хеширования пароля C # в Ruby.
Старая функция такова:
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
Я не получаю правильный хэш пароля (вместо "weEWx4rhyPtd3kec7usysxf7kpk =") я получаю "+ BsdIOBN / Vh2U7qWG4e + O13h3iQ =". Кто-нибудь может увидеть, в чем может быть проблема?
Большое спасибо
Arfon