首頁 >web前端 >js教程 >Node.Js如何實現比特幣地址

Node.Js如何實現比特幣地址

php中世界最好的语言
php中世界最好的语言原創
2018-04-27 14:27:382268瀏覽

這次帶給大家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:

59DEE66AB619C4A9E215D070052D1AE3A2075E5F58C675168582585 A75DB985072968C72B036ED97BA2EF2DECE2ABCA5BE14792

公鑰:

0459DEE66AB619C4A9E215D070052D1AE3A2075E5F58C67516B2E4884 792

3.計算公鑰的SHA-256雜湊值

ae9c74647a8c2f50fd832e397e36dbad05d86db3fe3d959a7c8a07c1#dc

#4.計算RIPEMD-160哈希值

#05f9d05358aab2a28f19910036e67a7295b14aac

5.加入地址版本號(比特幣主網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中文網其它相關文章!

推薦閱讀:

vue-cli專案中使用bootstrap步驟詳解

AngularJs如何防止XSS攻擊

#AngularJS使用Filter自訂篩選器案例詳解

以上是Node.Js如何實現比特幣地址的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn