首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何解析ecrecover参数?

如何解析ecrecover参数?
EN

Ethereum用户
提问于 2019-09-10 20:58:18
回答 1查看 254关注 0票数 0

我正在寻找从任何至少发送一次交易的ethereum地址(不是我所拥有的)获得公钥。看来,这里最可行的解决方案是使用ethereumjs utils。

代码语言:javascript
复制
/**
 * 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)
}

用户提到

当您发送事务时,您签署事务,它包括这些v和S值。您从签名的tx中解析这些值,然后将这些v、r和S值以及事务的has返回到一个函数中,它将吐出公钥。

最后一步我完全不清楚。我不明白我们如何解析"v“、"r”和"s“。

选择Etherscan.io上的随机事务散列,我们将如何“解析”v、r和S参数?

EN

回答 1

Ethereum用户

回答已采纳

发布于 2019-09-15 04:13:05

如果您有事务哈希,可以调用eth_getTransactionByHash,它将返回解析的事务字段,包括r、S和v。

代码语言:javascript
复制
{
  "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"
  }
}
票数 2
EN
页面原文内容由Ethereum提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://ethereum.stackexchange.com/questions/74845

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档