Ethereumjs

如何解析ecrecover參數?

  • September 15, 2019

我正在研究從至少發送一次交易的任何乙太坊地址(屬於我)獲取公鑰。似乎這裡最可行的解決方案是使用 ethereumjs-utils

/**
* ECDSA public key recovery from signature
* @param {Buffer} msgHash
* @param {Number} v
* @param {Buffer} r
* @param {Buffer} s
* @return {Buffer} publicKey
*/
exports.ecrecover = function (msgHash, v, r, s) {
 var signature = Buffer.concat([exports.setLength(r, 32), exports.setLength(s, 32)], 64)
 var recovery = v - 27
 if (recovery !== 0 && recovery !== 1) {
   throw new Error('Invalid signature v value')
 }
 var senderPubKey = secp256k1.recover(msgHash, signature, recovery)
 return secp256k1.publicKeyConvert(senderPubKey, false).slice(1)
}

使用者提到

當您發送交易時,您簽署了交易,它包括這些 vr 和 s 值。你從簽名的 tx 中解析這些,然後將這些 vr 和 s 值以及交易的 has 值傳遞回一個函式,它會吐出公鑰

這最後一步對我來說完全不清楚。我不明白我們如何解析“v”、“r”和“s”。

在Etherscan.io上選擇一個隨機交易雜湊,我們將如何“解析” v、r 和 s 參數?

如果您有交易雜湊,您可以呼叫eth_getTransactionByHash,它將返回交易的解析欄位,包括 r、s 和 v。

{
 "jsonrpc":"2.0",
 "id":1,
 "result":{
   "blockHash":"0x1d59ff54b1eb26b013ce3cb5fc9dab3705b415a67127a003c3e61eb445bb8df2",
   "blockNumber":"0x5daf3b", // 6139707
   "from":"0xa7d9ddbe1f17865597fbd27ec712455208b6b76d",
   "gas":"0xc350", // 50000
   "gasPrice":"0x4a817c800", // 20000000000
   "hash":"0x88df016429689c079f3b2f6ad39fa052532c56795b733da78a91ebe6a713944b",
   "input":"0x68656c6c6f21",
   "nonce":"0x15", // 21
   "to":"0xf02c1c8e6114b1dbe8937a39260b5b0a374432bb",
   "transactionIndex":"0x41", // 65
   "value":"0xf3dbb76162000", // 4290000000000000
   "v":"0x25", // 37
   "r":"0x1b5e176d927f8e9ab405058b2d2457392da3e20f328b16ddabcebc33eaac5fea",
   "s":"0x4ba69724e8f69de52f0125ad8b3c5c2cef33019bac3249e2c0a2192766d1721c"
 }
}

引用自:https://ethereum.stackexchange.com/questions/74845