Я использую SHA256, чтобы получить хешированную шестнадцатеричную строку. Он работает нормально при использовании обычных символов, однако, когда строка, которую нужно хэшировать, содержит акценты / диакритические знаки, тогда я получаю другой результат в C # и T-SQL. Я бы предпочел внести изменения в конце SQL Server.
- Пример слова, которое соответствует: птица
- Пример слова, которое не соответствует: MUÑOZ
C #
using (SHA256 sha2 = SHA256.Create())
{
var hash = sha2.ComputeHash(Encoding.UTF8.GetBytes(fullAddress));
string hexString = string.Empty;
for (int i = 0; i < hash.Length; i++)
{
hexString += hash[i].ToString("X2"); //Convert the byte to Hexadecimal representation, Notice that we use "X2" instead of "X"
}
sha2.Dispose();
return hexString;
}
SQL
declare @fullAddress nvarchar(500)
set @fullAddress = 'MUÑOZ'
select CONVERT([varchar](256), HASHBYTES('SHA2_256', @fullAddress), 2)