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的index方法实现tab效果
Feb 16 Javascript
前后台交互过程中json格式如何解析以及如何生成
Dec 26 Javascript
js导出table数据到excel即导出为EXCEL文档的方法
Oct 10 Javascript
clipboard.js无需Flash无需依赖任何JS库实现文本复制与剪切
Oct 10 Javascript
Bootstrap3 内联单选和多选框
Dec 29 Javascript
Vue项目组件化工程开发实践方案
Jan 09 Javascript
vue-router 组件复用问题详解
Jan 22 Javascript
jQuery实现动态加载select下拉列表项功能示例
May 31 jQuery
微信小程序 组件的外部样式externalClasses使用详解
Sep 06 Javascript
vue新建项目并配置标准路由过程解析
Dec 09 Javascript
基于JS实现视频上传显示进度条
May 12 Javascript
详解如何在Canvas中添加事件的方法
Apr 17 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
第三节 定义一个类 [3]
2006/10/09 PHP
《PHP编程最快明白》第三讲:php数组
2010/11/01 PHP
深入PHP运行环境配置的详解
2013/06/04 PHP
PHP error_log()将错误信息写入一个文件(定义和用法)
2013/10/25 PHP
PHP实现根据密码长度显示安全条
2017/07/04 PHP
YII2框架中查询生成器Query()的使用方法示例
2020/03/18 PHP
轻轻松松学习JavaScript
2007/02/25 Javascript
jquery 面包屑导航 具体实现
2013/06/05 Javascript
jquery动态加载select下拉框示例代码
2013/12/10 Javascript
有效提高JavaScript执行效率的几点知识
2015/01/31 Javascript
jquery实现焦点图片随机切换效果的方法
2015/03/12 Javascript
浅谈Jquery核心函数
2015/06/18 Javascript
js实现鼠标点击文本框自动选中内容的方法
2015/08/20 Javascript
jQuery实现移动端手机商城购物车功能
2016/09/24 Javascript
js获取Get值的方法
2016/09/29 Javascript
很棒的一组js图片轮播特效
2017/01/12 Javascript
工厂模式在JS中的实践
2017/01/18 Javascript
js实现横向拖拽导航条功能
2017/02/17 Javascript
Vue header组件开发详解
2018/01/26 Javascript
Vue实现textarea固定输入行数与添加下划线样式的思路详解
2018/06/28 Javascript
微信小程序-form表单提交代码实例
2019/04/29 Javascript
微信小程序实现折线图的示例代码
2019/06/07 Javascript
基于vue+axios+lrz.js微信端图片压缩上传方法
2019/06/25 Javascript
vue集成chart.js的实现方法
2019/08/20 Javascript
Python装饰器的函数式编程详解
2015/02/27 Python
python显示生日是星期几的方法
2015/05/27 Python
Django中间件工作流程及写法实例代码
2018/02/06 Python
详谈Numpy中数组重塑、合并与拆分方法
2018/04/17 Python
python实现五子棋人机对战游戏
2020/03/25 Python
解决Python安装时报缺少DLL问题【两种解决方法】
2019/07/15 Python
Python之Class&amp;Object用法详解
2019/12/25 Python
说出数据连接池的工作机制是什么?
2013/04/19 面试题
阿里巴巴的Oracle DBA笔试题答案-SQL tuning类
2016/04/03 面试题
小学生开学第一课活动方案
2014/03/27 职场文书
大一工商管理职业生涯规划:有梦最美,行动相随
2014/09/18 职场文书
使用Canvas绘制一个游戏人物属性图
2022/03/25 Javascript