我正在使用以下代码来执行 SHA256。
public static string GenerateSaltedHash(string plainTextString, string saltString)
{
byte[] salt = Encoding.UTF8.GetBytes(saltString);
byte[] plainText = Encoding.UTF8.GetBytes(plainTextString);
HashAlgorithm algorithm = new SHA256Managed();
byte[] plainTextWithSaltBytes =
new byte[plainText.Length + salt.Length];
for (int i = 0; i < plainText.Length; i++)
{
plainTextWithSaltBytes[i] = plainText[i];
}
for (int i = 0; i < salt.Length; i++)
{
plainTextWithSaltBytes[plainText.Length + i] = salt[i];
}
byte[] bytes = algorithm.ComputeHash(plainTextWithSaltBytes);
return Convert.ToBase64String(algorithm.ComputeHash(plainTextWithSaltBytes));
}
由于我使用的是 SHA256,我预计结果的长度为 64。但我得到的是 44。
有什么问题吗?较短的输出长度会影响安全性吗?
Base-64 是每个字符 6 位 (2^6 = 64)。
256 bits / 6 bits per char = 42.6666 char
由于填充,这显然最终变成了 44(你会看到一两个=
在输出的末尾)。
您必须期待以 16 为基数(也称为十六进制),即每个字符 4 位 (2^4 = 16)。
256 bits / 4 bits per char = 64 char
用于六角使用this https://stackoverflow.com/a/623184/360211:
return BitConverter.ToString(bytes).Replace("-", string.Empty);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)