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("標(biāo)準(zhǔn)地址:" + 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
//這里還缺失校驗(yàn)和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.生成隨機(jī)私鑰,私鑰是一個(gè)32字節(jié)的數(shù) 例如:
8F72F6B29E6E225A36B68DFE333C7CE5E55D83249D3D2CD6332671FA445C4DD3
2.橢圓曲線計(jì)算公鑰 生成了私鑰之后,我們使用橢圓曲線加密算法(ECDSA-secp256k1)計(jì)算私鑰所對應(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.加入地址版本號(比特幣主網(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之外的英文字符組成。 對上一步的結(jié)果進(jìn)行Base58編碼,得到:
1YbeKoyePe8gxyAYh4E3Qyqb15Nnepmod
這就是我們經(jīng)??吹降膫鹘y(tǒng)意義上的比特幣錢包地址了。
相關(guān)文章
Node.js中Sequelize?hook的使用方法小結(jié)
Sequelize?提供了多個(gè)?hook,用于在執(zhí)行數(shù)據(jù)庫操作時(shí)執(zhí)行一些自定義邏輯,本文為大家整理了一些常用的?Sequelize?hook?列表及其作用,希望對大家有所幫助2024-02-02
150行Node.js實(shí)現(xiàn)的dns代理工具
這篇文章主要介紹了150行Node.js實(shí)現(xiàn)的dns代理工具,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08
Node.js實(shí)現(xiàn)修改文件字符集功能的具體過程
在日常生活、工作中,我們經(jīng)常會(huì)遇到需要處理不同編碼格式的文件,有時(shí),在嘗試打開這些文件時(shí)會(huì)遇到亂碼,原因通常是文件的編碼與我們使用的文本編輯器或編程語言的默認(rèn)編碼不匹配,這篇文章將介紹Node.js修改文件字符集的實(shí)現(xiàn)思路和具體實(shí)現(xiàn)過程2024-08-08
深入學(xué)習(xí)nodejs中的async模塊的使用方法
本篇文章主要介紹了nodejs中的async模塊的使用方法,具有一定的參考價(jià)值,有興趣的可以了解一下2017-07-07
nvm對Node.js進(jìn)行版本控制的實(shí)現(xiàn)
本文主要介紹了用nvm來管理Node.js版本,通過nvm用戶可以輕松地在不同版本的Node.js之間切換,具有一定的參考價(jià)值,感興趣的可以了解一下2024-12-12

