国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

Node.Js生成比特幣地址代碼解析

2019-11-19 13:59:18
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

使用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("標(biāo)準(zhǔn)地址:" + publicKey.toString('hex'))//compressedpublicKey = curvePt.getEncoded(true) //true forces compressed public keyconsole.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 keyconsole.log("pubkeyHash:" + pubkeyHash.toString('hex')) // address of compressed public keyconsole.log("壓縮地址:" + cs.encode(pubkeyHash, 0x0)) //<-- 0x0 is for public addresses//這里還缺失校驗(yàn)和Base58編碼console.log(cs.encode(privateKey, 0x80)) //<--- 0x80 is for private addressesconsole.log(cs.encode(Buffer.concat([privateKey, new Buffer([0])]), 0x80)) // <-- compressed private address

生成比特幣地址

1.生成隨機(jī)私鑰,私鑰是一個(gè)32字節(jié)的數(shù) 例如:

8F72F6B29E6E225A36B68DFE333C7CE5E55D83249D3D2CD6332671FA445C4DD3

2.橢圓曲線計(jì)算公鑰 生成了私鑰之后,我們使用橢圓曲線加密算法(ECDSA-secp256k1)計(jì)算私鑰所對(duì)應(yīng)的非壓縮公鑰,生成的公鑰共65字節(jié), 第一個(gè)字節(jié)是0x04,后32個(gè)字節(jié)是X坐標(biāo),32個(gè)字節(jié)是Y坐標(biāo): 公鑰P.X:

59DEE66AB619C4A9E215D070052D1AE3A2075E5F58C67516B2E4884A88C79BE9 公鑰P.Y: A5FA8CCD255FB0A7A75DB985072968C72B036ED97BA2EF2DECE2ABCA5BE14792

公鑰:

0459DEE66AB619C4A9E215D070052D1AE3A2075E5F58C67516B2E4884A88C79BE9A5FA8CCD255FB0A7A75DB985072968C72B036ED97BA2EF2DECE2ABCA5BE14792

3.計(jì)算公鑰的SHA-256哈希值

ae9c74647a8c2f50fd832e397e36dbad05d86db3fe3d959a7c8a07c1ddda40c6

4.計(jì)算 RIPEMD-160哈希值

05f9d05358aab2a28f19910036e67a7295b14aac

5.加入地址版本號(hào)(比特幣主網(wǎng) 0x00)

0005f9d05358aab2a28f19910036e67a7295b14aac

其實(shí)這里就差不多了,也就是上面代碼最后生成的壓縮地址。

但在實(shí)際比特幣中,還要加上校驗(yàn)

6.計(jì)算 SHA-256 哈希值

9f35b0c37977a302512c22f586dd8da4ae1d20399f2ad3f75df23fbc024b4b2d

7.再次計(jì)算 SHA-256 哈希值

4b4f9bc87616687957db64efaf4efb2c00d1d93d549a0b70b15812936046d0ac

8.取上一步結(jié)果的前4個(gè)字節(jié)(8位十六進(jìn)制)

4b4f9bc8

9.把這4個(gè)字節(jié)加到第五步生成的壓縮地址后邊

0005f9d05358aab2a28f19910036e67a7295b14aac4b4f9bc8

10.用Base58編碼

Base58由1-9和除i,l,0,o之外的英文字符組成。 對(duì)上一步的結(jié)果進(jìn)行Base58編碼,得到:

1YbeKoyePe8gxyAYh4E3Qyqb15Nnepmod

這就是我們經(jīng)常看到的傳統(tǒng)意義上的比特幣錢包地址了。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 潜江市| 纳雍县| 临湘市| 新营市| 舟曲县| 焦作市| 长治县| 济阳县| 堆龙德庆县| 镇安县| 遂川县| 富顺县| 沙雅县| 游戏| 红安县| 工布江达县| 汝南县| 贡觉县| 广汉市| 安平县| 红安县| 苗栗市| 江油市| 乐东| 葫芦岛市| 禄丰县| 克拉玛依市| 吉首市| 江门市| 中江县| 昌都县| 万源市| 阆中市| 万源市| 封丘县| 延吉市| 连山| 丰城市| 始兴县| 定西市| 虹口区|