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 相关文章推荐
javascript中[]和{}对象使用介绍
Mar 20 Javascript
JS格式化数字金额用逗号隔开保留两位小数
Oct 18 Javascript
JQuery为页面Dom元素绑定事件及解除绑定方法
Apr 23 Javascript
js使用正则实现ReplaceAll全部替换的方法
Aug 22 Javascript
node.js中watch机制详解
Nov 17 Javascript
继续学习javascript闭包
Dec 03 Javascript
详解windows下vue-cli及webpack 构建网站(二)导入bootstrap样式
Jun 17 Javascript
vue.js使用3DES加密的方法示例
May 18 Javascript
webpack4.0 入门实践教程
Oct 08 Javascript
小程序如何支持使用 async/await详解
Sep 12 Javascript
js+canvas实现两张图片合并成一张图片的方法
Nov 01 Javascript
NestJs使用Mongoose对MongoDB操作的方法
Feb 22 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
如何在PHP中使用Oracle数据库(1)
2006/10/09 PHP
如何在PHP中使用Oracle数据库(6)
2006/10/09 PHP
PHP中file_get_contents函数抓取https地址出错的解决方法(两种方法)
2015/09/22 PHP
jquery中获得$.ajax()事件返回的值并添加事件的方法
2010/04/15 Javascript
分享一个自定义的console类 让你不再纠结JS中的调试代码的兼容
2012/04/20 Javascript
JQuery选择器特辑 详细小结
2012/05/14 Javascript
如何让页面在打开时自动刷新一次让图片全部显示
2012/12/17 Javascript
javascript中的toFixed固定小数位数 简单实例分享
2013/07/12 Javascript
获取3个数组不重复的值的具体实现
2013/12/30 Javascript
freemarker判断对象是否为空的方法
2015/08/13 Javascript
js实现适用于素材网站的黑色多级菜单导航条效果
2015/08/24 Javascript
javascript之Boolean类型对象
2016/06/07 Javascript
jQuery EasyUI常用数据验证汇总
2016/09/18 Javascript
canvas简单快速的实现知乎登录页背景效果
2017/05/08 Javascript
详解使用nvm管理多版本node的方法
2017/08/30 Javascript
JS笛卡尔积算法与多重数组笛卡尔积实现方法示例
2017/12/01 Javascript
Angular实现的敏感文字自动过滤与提示功能示例
2017/12/29 Javascript
js验证账户名是否重复
2020/05/26 Javascript
python使用心得之获得github代码库列表
2014/06/25 Python
python编写暴力破解FTP密码小工具
2014/11/19 Python
Python的Django框架中URLconf相关的一些技巧整理
2015/07/18 Python
Python中动态创建类实例的方法
2017/03/24 Python
python PyTorch参数初始化和Finetune
2018/02/11 Python
python 处理dataframe中的时间字段方法
2018/04/10 Python
Django + Uwsgi + Nginx 实现生产环境部署的方法
2018/06/20 Python
python linecache 处理固定格式文本数据的方法
2019/01/08 Python
详解Python3中ceil()函数用法
2019/02/19 Python
用Python抢火车票的简单小程序实现解析
2019/08/14 Python
美国最佳选择产品网站:Best Choice Products
2019/05/27 全球购物
火山动力Java笔试题
2014/06/26 面试题
生产助理岗位职责
2014/06/18 职场文书
院系推荐意见
2015/06/05 职场文书
迁徙的鸟观后感
2015/06/09 职场文书
2016年教师节感恩寄语
2015/12/04 职场文书
python绘图subplots函数使用模板的示例代码
2021/04/30 Python
Mysql事务索引知识汇总
2022/03/17 MySQL