1

我正在使用 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
4

2 回答 2

3

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

  1. Web3js 示例

在此处输入图像描述


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

  1. Web3j 示例 (kotlin)

在此处输入图像描述

于 2020-10-13T09:20:50.430 回答
-2

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

于 2020-12-25T06:14:25.853 回答