Golang SHA512 不匹配 OpenSSL SHA512

标签 go openssl sha

我正在尝试在 bash 中生成字符串的 SHA512 哈希,然后在 golang 中验证 SHA512 哈希。但是,我无法弄清楚实用程序/标志的确切组合来获得在两个地方产生的相同哈希值。
巴什代码:

echo "hello sha world" | openssl dgst -sha512 -hex
9c5b761a9bf8f74da84c57101669b8042b860ca5871a15c4e729758ad1dee58d562ddf8fa303ada1f3e0278fdff4af9a72f57ce0514be98f6a959daabda926f5
戈朗代码:
s := sha512.New()
s.Write([]byte(`hello sha world`))
fmt.Println(hex.EncodeToString(s.Sum(nil)))

d13fa494d2609a6f67e906de96d92788bd8ab46dec0f5e48d8cdb8c540628a752aa135262aa5804dcc907e261abe4472faf01fc13eb97e4e8c85e5c0438f2acb
我还尝试了二进制表示的base64编码,但没有任何运气:
重击:
echo "hello sha world"  | openssl dgst -sha512 | openssl base64 -A
OWM1Yjc2MWE5YmY4Zjc0ZGE4NGM1NzEwMTY2OWI4MDQyYjg2MGNhNTg3MWExNWM0ZTcyOTc1OGFkMWRlZTU4ZDU2MmRkZjhmYTMwM2FkYTFmM2UwMjc4ZmRmZjRhZjlhNzJmNTdjZTA1MTRiZTk4ZjZhOTU5ZGFhYmRhOTI2ZjUK
戈朗:
s := sha512.New()
s.Write([]byte(`hello sha world`))
fmt.Println(base64.RawStdEncoding.EncodeToString(s.Sum(nil)))

0T+klNJgmm9n6QbeltkniL2KtG3sD15I2M24xUBiinUqoTUmKqWATcyQfiYavkRy+vAfwT65fk6MheXAQ48qyw
关于如何让 Golang 生成与 openssl 相同的哈希的任何帮助将不胜感激。提前致谢!

最佳答案

echo命令还发送换行符,因此您的第一个示例计算字符串 "hello sha world\n" 的 SHA-512 校验和.
如果你在 Go 中使用相同的,你会得到相同的输出:

s := sha512.New()
s.Write([]byte("hello sha world\n"))
fmt.Println(hex.EncodeToString(s.Sum(nil)))
或者简单地说:
fmt.Printf("%x\n", sha512.Sum512([]byte("hello sha world\n")))
这些输出(在 Go Playground 上尝试):9c5b761a9bf8f74da84c57101669b8042b860ca5871a15c4e729758ad1dee58d562ddf8fa303ada1f3e0278fdff4af9a72f57ce0514be98f6a959daabda926f5如果您想计算 bash 中某些文本的 SHA-512 check out 而不使用尾随换行符,请使用 -n echo 的参数像这样:
echo -n "hello sha world" | openssl dgst -sha512 -hex
这输出与原始 Go 代码相同:d13fa494d2609a6f67e906de96d92788bd8ab46dec0f5e48d8cdb8c540628a752aa135262aa5804dcc907e261abe4472faf01fc13eb97e4e8c85e5c0438f2acb

关于Golang SHA512 不匹配 OpenSSL SHA512,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63287431/

相关文章:

ssl - 在有或没有 BIO 的情况下使用 OpenSSL TLS?

ssl - 如何在没有可导出私钥的情况下进行 ECDHE 握手

openssl - 如何篡改X509格式的证书?

javascript - 如何为完整性 html 标签生成 SHA?

algorithm - IPFS : is it possible? 中的哈希冲突/限制

go - 在 Go 中不断出现随机 TLS 握手错误

amazon-web-services - 突发数据处理的最佳 EC2 实例

google-app-engine - Blobstore 阅读器不会读取大图像

ubuntu - Go time.Ticker 在 Ubuntu 16.04 服务器上意外触发

algorithm - 单个 "1"位的 SHA-256 哈希值是多少?