今天我将我的 Web 应用程序迁移到 .net 4.0 并且 Forms Auth 刚刚停止工作。经过几个小时的挖掘我的SqlMembershipProvider(内置SqlMembershipProvider的简化版),我发现HMACSHA256哈希并不一致。这是加密方法:
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 3.5 中运行良好
任何人都知道任何重大更改,还是已知的错误?
更新:当我将 SHA512 指定为散列算法时,一切正常,所以我相信这是在 .NET 4.0 中实现 HMACSHA256 散列算法的错误
谢谢!安德烈