主页 > imtoken钱包官网 > Node.Js生成比特币地址(附代码)

Node.Js生成比特币地址(附代码)

imtoken钱包官网 2023-07-01 15:16:35

本次为大家带来Node.Js生成比特币地址(附代码),以及Node.Js生成比特币地址的注意事项有哪些。 下面是一个实际案例,一起来看看吧。

使用 Node.js,IDE 使用 sublime 3。

var randomBytes = require('randombytes')
var BigInteger = require('bigi')
var ecurve = require('ecurve')
var crypto = require('crypto')
var cs = require('coinstring')
var secp256k1 = ecurve.getCurveByName('secp256k1')
var randombytes = randomBytes(32).toString('hex')
var privateKey = new Buffer(randombytes, 'hex')

比特币是金莱特币是银_比特币的英文代码是多少_比特币挖矿代码图

console.log("私钥:" + privateKey.toString('hex')) var ecparams = ecurve.getCurveByName('secp256k1') var curvePt = ecparams.G.multiply(BigInteger.fromBuffer(privateKey)) var x = curvePt.affineX.toBuffer(32) var y = curvePt.affineY.toBuffer(32) var publicKey = Buffer.concat([new Buffer([0x04]), x, y]) console.log("标准地址:" + publicKey.toString('hex')) //compressed publicKey = curvePt.getEncoded(true) //true forces compressed public key

比特币挖矿代码图_比特币的英文代码是多少_比特币是金莱特币是银

console.log("compressed:" + publicKey.toString('hex')) var sha = crypto.createHash('sha256').update(publicKey).digest() var pubkeyHash = crypto.createHash('rmd160').update(sha).digest() // pubkeyHash of compressed public key console.log("pubkeyHash:" + pubkeyHash.toString('hex')) // address of compressed public key console.log("压缩地址:" + cs.encode(pubkeyHash, 0x0)) //<-- 0x0 is for public addresses //这里还缺失校验和Base58编码 console.log(cs.encode(privateKey, 0x80)) //<--- 0x80 is for private addresses

比特币挖矿代码图_比特币是金莱特币是银_比特币的英文代码是多少

console.log(cs.encode(Buffer.concat([privateKey, new Buffer([0])]), 0x80)) // <-- compressed private address

生成比特币地址

1. 生成随机私钥。 私钥是一个 32 字节的数字。 例如:

8F72F6B29E6E225A36B68DFE333C7CE5E55D83249D3D2CD6332671FA445C4DD3

2. 椭圆曲线计算公钥 生成私钥后比特币的英文代码是多少比特币的英文代码是多少,我们使用椭圆曲线加密算法(ECDSA-secp256k1)计算私钥对应的未压缩公钥。 生成的公钥共有 65 个字节。 第一个字节为0x04,后32个字节为X坐标,后32个字节为Y坐标: 公钥PX:

59DEE66AB619C4A9E215D070052D1AE3A2075E5F58C67516B2E4884A88C79BE9 ​​公钥 PY:A5FA8CCD255FB0A7A75DB985072968C72B036ED97BA2EF2DECE2ABCA5BE14792

公钥:

0459DEE66AB619C4A9E215D070052D1AE3A2075E5F58C67516B2E4884A88C79BE9A5FA8CCD255FB0A7A75DB985072968C72B036ED97BA2EF2DECE2ABCA5BE14792

3.计算公钥的SHA-256哈希值

比特币是金莱特币是银_比特币的英文代码是多少_比特币挖矿代码图

ae9c74647a8c2f50fd832e397e36dbad05d86db3fe3d959a7c8a07c1ddda40c6

4.计算RIPEMD-160哈希值

05f9d05358aab2a28f19910036e67a7295b14aac

5、添加地址版本号(比特币主网0x00)

0005f9d05358aab2a28f19910036e67a7295b14aac

其实这里差不多,就是上面代码在最后生成的压缩地址。

但在实际的比特币中,还添加了校验和

6.计算SHA-256哈希值

9f35b0c37977a302512c22f586dd8da4ae1d20399f2ad3f75df23fbc024b4b2d

比特币的英文代码是多少_比特币挖矿代码图_比特币是金莱特币是银

7.再次计算SHA-256哈希值

4b4f9bc87616687957db64efaf4efb2c00d1d93d549a0b70b15812936046d0ac

8.取上一步结果的前4个字节(8位十六进制)

4b4f9bc8

9.将这4个字节添加到第五步生成的压缩地址中

0005f9d05358aab2a28f19910036e67a7295b14aac4b4f9bc8

10. Base58编码

Base58由1-9和除i、l、0、o以外的英文字符组成。 对上一步的结果进行Base58编码得到:

1YbeKoyePe8gxyAYh4E3Qyqb15Nnepmod

相信看完本文的案例,你已经掌握了方法。 更多精彩请关注php中文网其他相关文章!