【问题标题】:Signatures different in web3j and web3js?web3j 和 web3js 中的签名不同?
【发布时间】:2023-04-10 18:18:02
【问题描述】:

我正在使用 web3J 版本“org.web3j:core:4.6.0”并遇到以下问题。当我签署相同的原始消息(字符串)时,我使用 web3js 和 web3j 得到不同的签名。 web3js 的签名有效(而 web3j 无效),我使用solidity ecrecover 函数对其进行了测试。值得一提的是,您在 sn-ps 中看到的哈希值是相同的。

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

【问题讨论】:

  • 当我运行你的 web3js 代码时,我得到了不同的签名结果。 ν: '0x1b',R: '0x3fbb576312b403bf1da04c68f375b23cc06516da80d39f7112f78c9232c3e253',S: '0x2496d070aabd14d6bcfbb52db9f0a7ec3df86224f2a0e4d5f5269cca1befcc1d',我使用的console.log(符号)打印出上述结果。你知道为什么吗? @Guarav

标签: android web3js web3-java


【解决方案1】:

首先,使用您的 js 示例和最新的 web3 lib (1.3.0) 我得到以下结果:

  1. Web3js 示例


然后,在您的 java 代码中,您需要使用 signPrefixedMessage,因为 web3js 版本包装了输入消息,对其进行哈希处理,然后才进行签名。此外,如果十六进制消息,web3js 将其正确转换为字节数组,您只需使用字符串字节。结果我收到了两个相同的签名。

  1. Web3j 示例 (kotlin)

【讨论】:

    【解决方案2】:

    ECDSA 具有随机分量,因此相同数据的签名应该不同

    【讨论】:

      猜你喜欢
      • 2021-12-25
      • 2021-08-10
      • 2021-12-26
      • 2021-02-28
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-01-20
      • 1970-01-01
      相关资源
      最近更新 更多