0

我正在尝试在 JS 中生成一个 sha3-512 哈希并在 golang 服务器中检查它。然而,cryptoJS 产生的哈希值与 golang 不同。

加密货币:

CryptoJS.algo.SHA3.create().update("foo").finalize().toString(CryptoJS.enc.Hex)

输出:

1597842aac52bc9d13fe249d808afbf44da13524759477404c3592ee331173e89fe1cbf21a7e4360990d565fad4643cdb209d80fa41a91dea97e665022c92135


戈朗:

hex.EncodeToString(crypto.SHA3_512.New().Sum([]byte("foo")))

输出:

666f6fa69f73cca23a9ac5c8b567dc185a756e97c982164fe25859e0d1dcc1475c80a615b2123af1f5f94c11e3e9402c3ac558f500199d95b6d3e301758586281dcd26

我希望这些哈希值相等,但它们不是

4

2 回答 2

4

我不知道您使用的是谁的 sha3 包。这是我使用此代码得到的结果:

package main

import (
    "fmt"
    "golang.org/x/crypto/sha3"
)

func main() {
    h := sha3.New512()
    h.Write([]byte("foo"))
    sum := h.Sum(nil)
    fmt.Printf("hash = %x\n", sum)
}

hash = 4bca2b137edc580fe50a88983ef860ebaca36c857b1f492839d6d7392452a63c82cbebc68e3b70a2a1480b4bb5d437a7cba6ecf9d89f9ff3ccd14cd6146ea7e7

与 Python3 比较:

>>> import hashlib
>>> print(hashlib.sha3_512(b"foo").hexdigest())

打印:

4bca2b137edc580fe50a88983ef860ebaca36c857b1f492839d6d7392452a63c82cbebc68e3b70a2a1480b4bb5d437a7cba6ecf9d89f9ff3ccd14cd6146ea7e7

于 2019-10-06T23:09:01.973 回答
2

显然,您的输出是 134 宽度,应该是 128 宽度。

让我们解码您的输出:

bytes, _ := hex.DecodeString("666f6fa69f73cca23a9ac5c8b567dc185a756e97c982164fe25859e0d1dcc1475c80a615b2123af1f5f94c11e3e9402c3ac558f500199d95b6d3e301758586281dcd26")
fmt.Printf("%s\n", bytes)

我们发现输出是foo��s̢:��ȵg�Zun�ɂO�XY����G\���:���L��@,:�X������u��(�&.

这意味着您实际上所做的是输出:

"foo" + sha3("")

其中 sha3_512("") 是来自 SHA3_512("") 的 "a69f73cca23a9ac5c8b567dc185a756e97c982164fe25859e0d1dcc1475c80a615b2123af1f5f94c11e3e9402c3ac558f500199d95b6d31e3017588586的变体示例

于 2019-10-06T23:41:00.680 回答