Node.Js生成比特币地址代码解析


Posted in Javascript onApril 21, 2018

使用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编码,得到:

1YbeKoyePe8gxyAYh4E3Qyqb15Nnepmod

这就是我们经常看到的传统意义上的比特币钱包地址了。

Javascript 相关文章推荐
jQuery 各种浏览器下获得日期区别
Dec 22 Javascript
js获取location.href的参数实例代码
Aug 02 Javascript
js与jquery获取父元素,删除子元素的两种不同方法
Jan 09 Javascript
JavaScript中最简洁的编码html字符串的方法
Oct 11 Javascript
jQuery 和 CSS 的文本特效插件集锦
Dec 12 Javascript
深究AngularJS——ng-checked(回写:带真实案例代码)
Jun 13 Javascript
JavaScript创建对象_动力节点Java学院整理
Jun 27 Javascript
详解webpack模块化管理和打包工具
Apr 21 Javascript
vue采用EventBus实现跨组件通信及注意事项小结
Jun 14 Javascript
解决Vue中引入swiper,在数据渲染的时候,发生不滑动的问题
Sep 27 Javascript
JavaScript监听触摸事件代码实例
Dec 30 Javascript
js实现页面图片消除效果
Mar 24 Javascript
vue.js与element-ui实现菜单树形结构的解决方法
Apr 21 #Javascript
JS装饰器函数用法总结
Apr 21 #Javascript
vue 之 .sync 修饰符示例详解
Apr 21 #Javascript
关于echarts在节点显示动态数据及添加提示文本所遇到的问题
Apr 20 #Javascript
vue中v-cloak解决刷新或者加载出现闪烁问题(显示变量)
Apr 20 #Javascript
jQuery中的$是什么意思及 $. 和 $().的区别
Apr 20 #jQuery
vue多页面开发和打包正确处理方法
Apr 20 #Javascript
You might like
如何冲泡挂耳包咖啡?技巧是什么
2021/03/04 冲泡冲煮
php下获取客户端ip地址的函数
2010/03/15 PHP
php中strstr、strrchr、substr、stristr四个函数的区别总结
2014/09/22 PHP
CI框架实现cookie登陆的方法详解
2016/05/18 PHP
php mysql PDO 查询操作的实例详解
2017/09/23 PHP
PHP实现的链式队列结构示例
2017/09/15 PHP
javascript 动态设置已知select的option的value值的代码
2009/12/16 Javascript
关于onScroll事件在IE6下每次滚动触发三次bug说明
2011/09/21 Javascript
第六篇Bootstrap表格样式介绍
2016/06/21 Javascript
jQuery实现移动端手机商城购物车功能
2016/09/24 Javascript
微信小程序 数组(增,删,改,查)等操作实例详解
2017/01/05 Javascript
JavaScript实现二维坐标点排序效果
2017/07/18 Javascript
详解vue+vuex+koa2开发环境搭建及示例开发
2018/01/22 Javascript
详解vue-flickity的fullScreen功能实现
2020/04/07 Javascript
vue router-link 默认a标签去除下划线的实现
2020/11/06 Javascript
11个并不被常用但对开发非常有帮助的Python库
2015/03/31 Python
Python处理JSON时的值报错及编码报错的两则解决实录
2016/06/26 Python
Jacobi迭代算法的Python实现详解
2019/06/29 Python
简单了解python中的与或非运算
2019/09/18 Python
python3+opencv生成不规则黑白mask实例
2020/02/19 Python
Python中Selenium模块的使用详解
2020/10/09 Python
Python爬虫定时计划任务的几种常见方法(推荐)
2021/01/15 Python
面料业务员岗位职责
2013/12/26 职场文书
农业资源与环境专业自荐信范文
2013/12/30 职场文书
档案信息化建设方案
2014/05/16 职场文书
大学生应聘求职信
2014/05/26 职场文书
人事任命书怎么写
2014/06/05 职场文书
党政领导班子民主生活会整改措施
2014/09/18 职场文书
2015元旦主持词开场白和结束语
2014/12/14 职场文书
2015年班组建设工作总结
2015/05/13 职场文书
演讲稿之感恩老师(三篇范文)
2019/09/06 职场文书
盘点2020年适合农村地区创业的项目
2019/10/16 职场文书
Python面向对象之成员相关知识总结
2021/06/24 Python
Python音乐爬虫完美绕过反爬
2021/08/30 Python
JavaScript中的宏任务和微任务详情
2021/11/27 Javascript
TV动画《神废柴☆偶像》公布先导PV
2022/03/20 日漫