【问题标题】:SQL Server HASHBYTES SHA2_512 and C#SQL Server HASHBYTES SHA2_512 和 C#
【发布时间】:2013-03-14 12:11:43
【问题描述】:

如果我在 SQL Server 中运行以下命令:

SELECT HASHBYTES('SHA2_512', 'THE CAT SAT ON THE MAT')

然后在 C# 中运行它

string test = WordFunctions.SHA512("THE CAT SAT ON THE MAT");

我得到了相同的价值,这很棒。但是,如果我在 C# 代码中传递一个字符串变量,则如下所示:

string words = "THE CAT SAT ON THE MAT"

byte[] test
test = WordFunctions.SHA512(words);

那我没有得到相同的值?!

有什么想法吗?

SHA512 函数如下所示:

public static byte[] SHA512(String plaintext)
{
   // convert the passPhrase string into a byte array
   ASCIIEncoding AE = new ASCIIEncoding();
   byte[] passBuff = AE.GetBytes(plaintext);

   SHA512Managed hashVal = new SHA512Managed();
   byte[] passHash = hashVal.ComputeHash(passBuff);

   return passHash;
}

【问题讨论】:

  • 你可以访问WordFunctions.SHA512的代码吗?
  • 是的,对不起,我应该把它包括在内!我将编辑原始帖子。
  • 所以,暂时忽略 SQL Server,您是在说 WordFunctions.SHA512("THE CAT SAT ON THE MAT");WordFunctions.SHA512(words); 其中 words = "THE CAT SAT ON THE MAT" 返回不同的东西?这似乎很奇怪。顺便说一句,更喜欢 UTF8Encoding 作为通用编码器。
  • 您的第一行代码不应编译,因为 SHA512 返回 byte[],而不是字符串。无论如何,我用你的 SHA512 方法代码对此进行了测试,当我比较它们时,两个 byte 数组是相同的。
  • @AakashM:他不能使用 UTF8,他必须使用 ASCII,因为编码必须匹配'THE CAT SAT ON THE MAT' 的 SQL,即 ASCII。

标签: c# sql-server encryption sqlclr


【解决方案1】:

以下代码对我有用:

private static readonly Encoding Encoding1252 = Encoding.GetEncoding(1252);

public static byte[] SHA1HashValue(string s)
{
    byte[] bytes = Encoding1252.GetBytes(s);

    var sha1 = SHA512.Create();
    byte[] hashBytes = sha1.ComputeHash(bytes);

    return hashBytes;
}

【讨论】:

  • 一般来说,如果答案包含对代码的用途的解释,以及为什么在不介绍其他人的情况下解决问题的原因,答案会更有帮助。
  • 谢谢,它帮助我弄清楚为什么我的 C# 生成的 SHA512 与我的 sql server 不同
猜你喜欢
  • 1970-01-01
  • 2011-04-12
  • 1970-01-01
  • 2016-08-24
  • 1970-01-01
  • 1970-01-01
  • 2021-01-05
  • 2011-04-11
  • 2021-12-09
相关资源
最近更新 更多