我正在尝试在JS中生成sha3-512哈希,并在golang服务器中对其进行检查。但是,cryptoJS产生的散列与golang不同。
CryptoJS:CryptoJS.algo.SHA3.create().update("foo").finalize().toString(CryptoJS.enc.Hex)
输出:
1597842aac52bc9d13fe249d808afbf44da13524759477404c3592ee331173e89fe1cbf21a7e4360990d565fad4643cdb209d80fa41a91dea97e665022c92135
Golang:hex.EncodeToString(crypto.SHA3_512.New().Sum([]byte("foo")))
输出:
666f6fa69f73cca23a9ac5c8b567dc185a756e97c982164fe25859e0d1dcc1475c80a615b2123af1f5f94c11e3e9402c3ac558f500199d95b6d3e301758586281dcd26
我希望这些哈希值相等,但不相同
我不知道您使用的是谁的sha3软件包。这是我通过this code获得的信息:
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
显然,您的输出是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(“”)是Examples of SHA-3 variants中的“ a69f73cca23a9ac5c8b567dc185a756e97c982164fe25859e0d1dcc1475c80a615b2123af1f5f94c11e3e9402c3ac558f500199d95b6d3e301758586281dcd26>