Node.Js生成比特币地址代码解析
使用Node.js,IDE采用sublime3。
varrandomBytes=require('randombytes')
varBigInteger=require('bigi')
varecurve=require('ecurve')
varcrypto=require('crypto')
varcs=require('coinstring')
varsecp256k1=ecurve.getCurveByName('secp256k1')
varrandombytes=randomBytes(32).toString('hex')
varprivateKey=newBuffer(randombytes,'hex')
console.log("私钥:"+privateKey.toString('hex'))
varecparams=ecurve.getCurveByName('secp256k1')
varcurvePt=ecparams.G.multiply(BigInteger.fromBuffer(privateKey))
varx=curvePt.affineX.toBuffer(32)
vary=curvePt.affineY.toBuffer(32)
varpublicKey=Buffer.concat([newBuffer([0x04]),x,y])
console.log("标准地址:"+publicKey.toString('hex'))
//compressed
publicKey=curvePt.getEncoded(true)//trueforcescompressedpublickey
console.log("compressed:"+publicKey.toString('hex'))
varsha=crypto.createHash('sha256').update(publicKey).digest()
varpubkeyHash=crypto.createHash('rmd160').update(sha).digest()
//pubkeyHashofcompressedpublickey
console.log("pubkeyHash:"+pubkeyHash.toString('hex'))
//addressofcompressedpublickey
console.log("压缩地址:"+cs.encode(pubkeyHash,0x0))//<--0x0isforpublicaddresses
//这里还缺失校验和Base58编码
console.log(cs.encode(privateKey,0x80))//<---0x80isforprivateaddresses
console.log(cs.encode(Buffer.concat([privateKey,newBuffer([0])]),0x80))//<--compressedprivateaddress
生成比特币地址
1.生成随机私钥,私钥是一个32字节的数例如:
8F72F6B29E6E225A36B68DFE333C7CE5E55D83249D3D2CD6332671FA445C4DD3
2.椭圆曲线计算公钥生成了私钥之后,我们使用椭圆曲线加密算法(ECDSA-secp256k1)计算私钥所对应的非压缩公钥,生成的公钥共65字节,第一个字节是0x04,后32个字节是X坐标,32个字节是Y坐标:公钥P.X:
59DEE66AB619C4A9E215D070052D1AE3A2075E5F58C67516B2E4884A88C79BE9公钥P.Y: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
这就是我们经常看到的传统意义上的比特币钱包地址了。