中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Node.Js如何生成比特幣地址

發布時間:2021-06-24 11:15:29 來源:億速云 閱讀:130 作者:小新 欄目:web開發

這篇文章給大家分享的是有關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字節的數 例如:

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編碼,得到:

1YbeKoyePe8gxyAYh5E3Qyqb15Nnepmod

這就是我們經常看到的傳統意義上的比特幣錢包地址了。

感謝各位的閱讀!關于“Node.Js如何生成比特幣地址”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

高雄市| 安西县| 尼勒克县| 平远县| 白城市| 周口市| 桐城市| 城步| 永泰县| 拜城县| 方正县| 金堂县| 三明市| 曲阜市| 澎湖县| 石河子市| 玉环县| 临湘市| 恩施市| 区。| 井冈山市| 新安县| 常宁市| 曲阳县| 东山县| 萝北县| 雷波县| 巫溪县| 沁阳市| 玉门市| 鄢陵县| 梁河县| 莱州市| 丰原市| 长治县| 亚东县| 霍林郭勒市| 盐源县| 丰镇市| 赣榆县| 隆昌县|