這次帶給大家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位元組的數字例如:
8F72F6B29E6E225A36B68DFE333C7CE5E55D832493D3D
#2.橢圓曲線計算公鑰產生了私鑰之後,我們使用橢圓曲線加密演算法(ECDSA-secp256k1)計算私鑰所對應的非壓縮公鑰,產生的公鑰共65字節, 第一位元組是0x04,後32個位元組是X座標,32個位元組是Y座標: 公鑰P.X:59DEE66AB619C4A9E215D070052D1AE3A2075E5F58C6751685857582P747572575338C38A A75DB985072968C72B036ED97BA2EF2DECE2ABCA5BE14792公鑰:
0459DEE66AB619C4A9E215D070052D1AE3A2075E5F58C67516B2E4884A88C79BE9A5FA8CCD255FB0A7A75DB985072968C72B036ED97BA2EF2DECE2ABCA5BE147923.計算公鑰的SHA-256哈希值
ae9c74647a8c2f50fd832e397e36dbad05d86db3fe3d959a7c8a07c1ddda40c64.計算RIPEMD-160哈希值
#05f9d05358aab2a28f19910036e67a7295b14aac5.加入地址版本號(比特幣主網0x
##0005f9d05358aab2a28f19910036e67a7295b14aac
但在實際比特幣中,還要加上校驗6.計算SHA-256 哈希值其實這裡就差不多了,也就是上面程式碼最後產生的壓縮位址。
9f35b0c37977a302512c22f586dd8da4ae1d20399f2ad3f75
#7.再計算SHA-256 雜湊值#4b4f9bc87616687957db64efaf4efb2c00d1d93d549a0b70b15812936046d00ac
829360
84acac##84制)4b4f9bc8
9.把這4個位元組加到第五步驟產生的壓縮位址後邊0005f9d05358aab2a28f19910036e67a7255358aab2a28f19910036e67a7255 ##10.用Base58編碼
Base58由1-9和除i,l,0,o之外的英文字元組成。對上一步的結果進行Base58編碼,得到:
1YbeKoyePe8gxyAYh4E3Qyqb15Nnepmod
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!推薦閱讀:
字串陣列去重實戰案例解析
以上是Node.Js產生比特幣地址(附代碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!