Я пишу свой собственный пользовательский провайдер членства, но использую собственный метод EncodePassword у провайдеров членства, который показан ниже:
internal string EncodePassword(string pass, int passwordFormat, string salt)
{
if (passwordFormat == 0) // MembershipPasswordFormat.Clear
return pass;
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);
if (passwordFormat == 1)
{ // MembershipPasswordFormat.Hashed
HashAlgorithm s = HashAlgorithm.Create( Membership.HashAlgorithmType );
bRet = s.ComputeHash(bAll);
} else
{
bRet = EncryptPassword( bAll );
}
return Convert.ToBase64String(bRet);
}
Теперь я знаю после нескольких часов охоты на это в .NET 4используется алгоритм HMACSHA256.Я понимаю, что мне нужен ключ для правильной работы алгоритма.
Мой вопрос: как это сделать?
Вставить ли ключ в файл конфигурации и ссылаться на него каким-либо образом?
Любая помощь будет оценена!
Спасибо.