如何解决web3j和web3js中的签名不同吗?
我正在使用web3J版本“ org.web3j:core:4.6.0 ”,并遇到以下问题。当我签名相同的原始消息(字符串)时,我使用web3js和web3j获得了不同的签名。 web3js的签名有效(而web3j无效),我使用solidity ecrecover函数对其进行测试。值得一提的是,您在摘要中看到的哈希是相同的。
Java代码(web3j)。
String private_key = "25218ba6de76757feba214961b588345e1415b267383af9fda13dd032ae75fff";
Credentials credentials1 = Credentials.create(privateKey1)
String message = "0x12cf1496120ada41033631fd6fa12613416c18696b70e4b072b3d1157ee165c7";
Sign.SignatureData signature = Sign.signMessage(message.getBytes(),credentials.getEcKeyPair());
String signature_V = Numeric.toHexString(signature.getV());
String signature_R = Numeric.toHexString(signature.getR());
String signature_S = Numeric.toHexString(signature.getS());
java代码结果-
signature_V=: 0x1b
signature_R=: 0x9f09f364e24577eb9dde9f1e3e2c0db0473fdd03e38945de0a5d97a92ee9b5c1
signature_S=: 0x3d7860741f64144ac8317880dc110ffadf020f712322f7c11bcf9cf3e446c212
使用web3js代码。
let privateKey = "25218ba6de76757feba214961b588345e1415b267383af9fda13dd032ae75fff"
let message = "0x12cf1496120ada41033631fd6fa12613416c18696b70e4b072b3d1157ee165c7";
let sign = web3.eth.accounts.sign(message,privateKey);
web3js结果-
signature_V=: 0x1b
signature_R=: 0x3db7bc52699c3b34d9b8b617c5e7646ce5b6899d278c061cf83dcd216316f0ef
signature_S=: 0x0dea9a606165cb7fc3e4b7959ba43f33025b44886c6363cd4d7788297a1cbf39
解决方法
首先,使用您的js示例和最新的web3 lib(1.3.0),我得到以下结果:
- Web3js示例
然后,在您的Java代码中,您需要使用signPrefixedMessage,因为web3js版本会包装输入消息,对其进行哈希处理,然后才进行签名。另外,如果消息以十六进制表示,则web3js会将其正确转换为字节数组,您只使用了字符串字节。结果,我收到了两个相同的签名。
- Web3j示例(kotlin)
ECDSA 具有随机分量,因此相同数据的签名应该是不同的
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。