В методе ChangePassword()
поставщика ASPMembership по умолчанию формат пароля для существующего пользователя извлекается из базы данных и представляет собой формат, используемый для кодирования нового пароля для существующего пользователя, а не формат пароля, который установлен в web.config
, который теперь может указывать другой формат для использования. Вы можете убедиться в этом сами, загрузив исходный код для поставщиков по умолчанию .
Тогда мой вопрос: хранится ли пароль в виде открытого текста для пользователя, у которого уже был пароль, хранящийся в виде открытого текста? Это легко проверить, проверив значение поля PasswordFormat для пользователя в таблице aspnet_Membership
. Значения:
Clear = 0,
Hashed = 1,
Encrypted = 2,
РЕДАКТИРОВАТЬ:
если вам нужно самостоятельно хэшировать пароли, код инфраструктуры может пригодиться
// generate a salt
public string GenerateSalt()
{
byte[] buf = new byte[16];
(new RNGCryptoServiceProvider()).GetBytes(buf);
return Convert.ToBase64String(buf);
}
// hashes the password, using the supplied salt
public string HashPassword(string pass, string salt)
{
byte[] bIn = Encoding.Unicode.GetBytes(pass);
byte[] bSalt = Convert.FromBase64String(salt);
byte[] bAll = new byte[bSalt.Length + bIn.Length];
byte[] bRet = null;
Buffer.BlockCopy(bSalt, 0, bAll, 0, bSalt.Length);
Buffer.BlockCopy(bIn, 0, bAll, bSalt.Length, bIn.Length);
// this assumes a Hashed password (PasswordFormat = 1)
HashAlgorithm s = HashAlgorithm.Create( Membership.HashAlgorithmType );
bRet = s.ComputeHash(bAll);
return Convert.ToBase64String(bRet);
}
теперь вам просто нужно извлечь все записи из базы данных, где PasswordFormat = 0, запустить их через консольное приложение, чтобы хэшировать пароль и сохранить соль, хешированный пароль в базе данных, а также обновить поле PasswordFormat до 1