【问题标题】:Hashvalue from SHA512 algorithm is 128 bits long?SHA512 算法的哈希值是 128 位长吗?
【发布时间】:2013-02-22 15:04:43
【问题描述】:

我有一个奇怪的问题。 在我的代码中,我创建了一个 sha512 哈希算法并用它签署了一些数据。 现在我希望散列的长度为 512 位,但实际上是 128。 我犯了什么错误?

我的代码:

var hashAlgorithm = HashAlgorithm.Create( „SHA512“ );
var signedhHash = rsaCryptoServiceProvider.SignData( plainData, hashAlgorithm );

PS。 我已经从使用以下脚本创建的文件中加载了 RSA 密钥:

makecert -r -n "CN=myCert" -sky exchange -sy 24 -sv myCert.pvk myCert.cer
cert2spc myCert.cer myCert.spc
pvk2pfx -pvk myCert.pvk -spc myCert.spc -pfx myCert.pfx –f

编辑:

我从signedhHash.Length得到长度,等于128。

【问题讨论】:

  • 你在哪里计算长度?
  • 计算长度?你的意思是这样的:signedhHash.Length (signedhHash.Length is equals to 128)
  • 你说“它有 128 位长”,你从哪里得到这个数字?
  • 如果你从signedhHash (128 bytes) 得到长度,那么实际上你有1024 bits。你在比较两个不同的东西

标签: c# hash sha512


【解决方案1】:

哈希值的大小是 512,但 签名的哈希值(来自 SignData)的大小是 1024。

var alg = HashAlgorithm.Create("SHA512");
var hashArr = alg.ComputeHash(ASCIIEncoding.UTF8.GetBytes("test"));
var size = hashArr.Length * 8; //512

var rsaCryptoServiceProvider = new RSACryptoServiceProvider();
var signedValue = rsaCryptoServiceProvider.SignData(ASCIIEncoding.UTF8.GetBytes("test"), alg);
size = signedValue.Length * 8; //1024

(1 字节 = 8 位)

【讨论】:

  • 当我回到页面发布我的答案时,我怎么没看到已经发布了答案
  • 非常感谢!所以这意味着signedhHash.Length总是等于rsaCryptoServiceProvider.KeySize / 8?
  • @SpaceghostAli:当我开始在 OP 上编写我的 cmets 时,我也没有看到这个答案.. Magnus 是魔术师吗?
【解决方案2】:

SignData 不返回使用 SHA512 算法生成的散列,它返回使用提供者的 SignatureAlgorithm 属性生成的散列的签名 (http://www.w3.org/2000/09/xmldsig#rsa-sha1)

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2018-12-03
    • 2013-08-16
    • 2018-06-07
    • 2011-03-02
    • 1970-01-01
    • 1970-01-01
    • 2011-05-30
    • 2018-11-28
    相关资源
    最近更新 更多