为什么我没有让sha256正确?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为什么我没有让sha256正确?相关的知识,希望对你有一定的参考价值。

我正在使用crypto ++库进行一些练习。我期待与从shell调用的sha256sum工具相同的输出。

// typedef unsigned char byte;
byte out[CryptoPP::SHA256::DIGESTSIZE];
byte in=65;  // 'A'
CryptoPP::SHA256().CalculateDigest(out, &in, 1);
for(int i=0; i < CryptoPP::SHA256::DIGESTSIZE; i++)
    std::cout << std::hex << (int)out[i];
std::cout << std::endl;

559اياد08264دخمسخدصصح18سددخبدد49572يضع4فخخصص0ييفع1اضضا08فدففد

$ echo A | sha256sum

06f961b802bc46ee168555f066d28f4f0e9afdf3f88174c1ee6f9de004fc30a0

为什么两者不相等?

答案

echo附加一个换行符,所以你要比较不同字符串的哈希值。使用printf代替:

$ printf 'A' | sha256sum
559aead08264d5795d3909718cdd05abd49572e84fe55590eef31a88a08fdffd  -
$ printf 'A
' | sha256sum
06f961b802bc46ee168555f066d28f4f0e9afdf3f88174c1ee6f9de004fc30a0  - 
另一答案

在命令行中,您将校验和A +换行符。

如果你的unix版本支持它,使用echo -n回声而不添加换行符;

$ echo -n A | sha256sum
559aead08264d5795d3909718cdd05abd49572e84fe55590eef31a88a08fdffd  -

以上是关于为什么我没有让sha256正确?的主要内容,如果未能解决你的问题,请参考以下文章

为什么hashlib比sha256的其他代码更快?如何让我的代码接近hashlib性能?

当信息中出现新行时,HMAC SHA-256是不正确的。

如何扩展 GPGPU 的顶点着色器功能

为啥我使用 OpenSSL 和 Java 生成的 RSA-SHA256 签名不同?

来自 nodejs 加密的 SHA256 不正确

是否有内置的方法或插件让Jenkins为我的工件生成SHA256哈希?