SHA256 не дает того же результата между C# и SQL Server при использовании испанских словC#

Место общения программистов C#
Ответить
Anonymous
 SHA256 не дает того же результата между C# и SQL Server при использовании испанских слов

Сообщение Anonymous »

Я использую SHA256, чтобы получить хешантизированную шестнадцатеричную строку. Он работает нормально при использовании обычных символов, однако, когда строка для хэширования включает в себя акценты/диаклитику, я получаю другой результат в C# и T-SQL. Я бы предпочел внести изменения в конце SQL Server. < /p>


Пример примера, которое соответствует: Bird < /li>
Пример слова, которое не соответствует: muñoz < /li>
< /ul>

C#< /p>

< /p>

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.ToString("X2"); //Convert the byte to Hexadecimal representation, Notice that we use "X2" instead of "X"
}

sha2.Dispose();
return hexString;
}
< /code>

sql < /p>

declare @fullAddress nvarchar(500)
set @fullAddress = 'MUÑOZ'
select CONVERT([varchar](256), HASHBYTES('SHA2_256', @fullAddress), 2)


Подробнее здесь: https://stackoverflow.com/questions/569 ... sing-spani
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»