cryptojs 和 golang 给出不同的 sha3 哈希值
cryptojs and golang give different sha3 hash values
我正在尝试在 JS 中生成一个 sha3-512 哈希并在 golang 服务器中检查它。但是,cryptoJS 生成的哈希与 golang 不同。
CryptoJS:
CryptoJS.algo.SHA3.create().update("foo").finalize().toString(CryptoJS.enc.Hex)
输出:
1597842aac52bc9d13fe249d808afbf44da13524759477404c3592ee331173e89fe1cbf21a7e4360990d565fad4643cdb209d80fa41a91dea97e665022c92135
戈朗:
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("") 是 "a69f73cca23a9ac5c8b567dc185a756e97c982164fe25859e0d1dcc1475c80a615b2123af1f5f94c11e3e9402c3ac558f500199d95b6d3e301758586281dcd26" 来自 Examples of SHA-3 variants。
我正在尝试在 JS 中生成一个 sha3-512 哈希并在 golang 服务器中检查它。但是,cryptoJS 生成的哈希与 golang 不同。
CryptoJS:
CryptoJS.algo.SHA3.create().update("foo").finalize().toString(CryptoJS.enc.Hex)
输出:
1597842aac52bc9d13fe249d808afbf44da13524759477404c3592ee331173e89fe1cbf21a7e4360990d565fad4643cdb209d80fa41a91dea97e665022c92135
戈朗:
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("") 是 "a69f73cca23a9ac5c8b567dc185a756e97c982164fe25859e0d1dcc1475c80a615b2123af1f5f94c11e3e9402c3ac558f500199d95b6d3e301758586281dcd26" 来自 Examples of SHA-3 variants。