Node.Js如何實現比特幣地址
這次帶給大家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 7923.計算公鑰的SHA-256雜湊值
ae9c74647a8c2f50fd832e397e36dbad05d86db3fe3d959a7c8a07c1#dc#4.計算RIPEMD-160哈希值
#05f9d05358aab2a28f19910036e67a7295b14aac
其實這裡就差不多了,也就是上面程式碼最後產生的壓縮位址。5.加入地址版本號(比特幣主網0x
##0005f9d05358aab2a28f19910036e67a7295b14aac
6.計算SHA-256 哈希值但在實際比特幣中,還要加上校驗
9f35b0c37977a302512c22f586dd8da4ae1d20399f2ad3f75
#7.再計算SHA-256 雜湊值#4b4f9bc87616687957db64efaf4efb2c00d1d93d549a0b70b15812936046d00ac82936084acac
##84制)
4b4f9bc8
9.把這4個位元組加到第五步驟產生的壓縮位址後邊
##10.用Base58編碼Base58由1-9和除i,l,0,o之外的英文字元組成。對上一步的結果進行Base58編碼,得到:0005f9d05358aab2a28f19910036e67a7255358aab2a28f19910036e67a7255
1YbeKoyePe8gxyAYh4E3Qyqb15Nnepmod相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章! 推薦閱讀:
vue-cli專案中使用bootstrap步驟詳解
AngularJs如何防止XSS攻擊
#AngularJS使用Filter自訂篩選器案例詳解以上是Node.Js如何實現比特幣地址的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

apple官方售後電話蘋果24小時服務中心電話:400-666-8800。蘋果手機售後電話人工服務電話是:400-666-8800。 -627-2273。蘋果客服人工服務電話是售後支援400-627-2273;線上商店400-666-8800;蘋果官方電話唯一號碼就是400-666-8800。蘋果客服人工服務電話是400-666-8800,您可以撥打此電話諮詢蘋果產品的硬體、軟體和第三方配件產品問題。需要注意的是,蘋果的人工客服並非24小時提供服務,他們的服務時間為早上9點至晚上9點(週日為9點至

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

一、美團地址在哪裡改?美團地址修改教學!方法(一)1.進入美團我的頁面,點選設定。 2.選擇個人資訊。 3.再點選收貨地址。 4.最後選擇要修改的地址,點選地址右側的筆圖標,修改即可。方法(二)1.在美團app首頁,點選外賣,進入後點選更多功能。 2.在更多介面,點選管理地址。 3.在我的收貨地址介面,選擇編輯。 4.依需求一一修改,最後點選儲存地址即可。

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

路由器是網路中非常重要的設備之一,起到了連接多個設備並進行資料傳輸的作用。在路由器的配置中,有一個重要的參數是位址租期(AddressLeaseTime),其意義對於網路連線和管理至關重要。本文將詳細介紹路由器位址租期的意義與作用。位址租期是指路由器給予連接設備使用IP位址的時間週期。每個設備連接到路由器後,會自動取得一個臨時的IP位址,這個位址在一定的

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We
