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),我得到以下结果:

  1. Web3js示例

enter image description here


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

  1. Web3j示例(kotlin)

enter image description here

,

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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...