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 异步调用框架 (Part 6 - 实例 &amp; 模式)
Aug 04 Javascript
JavaScript对HTML DOM使用EventListener进行操作
Oct 21 Javascript
js为什么不能正确处理小数运算?
Dec 29 Javascript
JS中的==运算: [''] == false —&gt;true
Jul 24 Javascript
js获取Get值的方法
Sep 29 Javascript
JavaScript实现页面定时刷新(定时器,meta)
Oct 12 Javascript
详解小程序循环require之坑
Mar 08 Javascript
详解用vue2.x版本+adminLTE开源框架搭建后台应用模版
Mar 15 Javascript
利用js-cookie实现前端设置缓存数据定时失效
Jun 18 Javascript
基于javascript处理nginx请求过程详解
Jul 07 Javascript
vue解决跨域问题(推荐)
Nov 10 Javascript
JavaScript实现页面动态验证码的实现示例
Mar 23 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/03 咖啡文化
PHP实现把文本中的URL转换为链接的auolink()函数分享
2014/07/29 PHP
YII2框架中日志的配置与使用方法实例分析
2020/03/18 PHP
优化javascript的执行速度
2010/01/23 Javascript
javascript两段代码,两个小技巧
2010/02/04 Javascript
利用jquery操作select下拉列表框的代码
2010/06/04 Javascript
JQuery优缺点分析说明
2011/04/10 Javascript
JS实现金额转换(将输入的阿拉伯数字)转换成中文的实现代码
2013/09/30 Javascript
js中的preventDefault与stopPropagation详解
2014/01/29 Javascript
JavaScript将取代AppleScript?
2014/09/18 Javascript
原生js编写autoComplete插件
2016/04/13 Javascript
node.js cookie-parser之parser.js
2016/06/06 Javascript
Node.js DES加密的简单实现
2016/07/07 Javascript
JavaScript数组操作详解
2017/02/04 Javascript
浅谈jQuery框架Ajax常用选项
2017/07/08 jQuery
微信小程序progress组件使用详解
2018/01/31 Javascript
对vux点击事件的优化详解
2018/08/28 Javascript
nodejs中函数的调用实例详解
2018/10/31 NodeJs
Vue3.0结合bootstrap创建多页面应用
2019/05/28 Javascript
Webpack 4如何动态切割JS注入文件名详解
2019/07/09 Javascript
typescript配置alias的详细步骤
2020/08/12 Javascript
python实现校园网自动登录的示例讲解
2018/04/22 Python
python库lxml在linux和WIN系统下的安装
2018/06/24 Python
Python基于模块Paramiko实现SSHv2协议
2020/04/28 Python
python实现粒子群算法
2020/10/15 Python
HTML5 Canvas实现烟花绽放特效
2016/03/02 HTML / CSS
Philosophy美国官网:美国美容品牌
2016/08/15 全球购物
高中的自我鉴定
2013/12/16 职场文书
投标承诺书怎么写
2014/05/24 职场文书
艺术设计专业毕业生推荐信
2014/07/08 职场文书
小区门卫的岗位职责
2014/09/26 职场文书
护士自我推荐信范文
2015/03/24 职场文书
党小组推荐意见
2015/06/02 职场文书
如何书写邀请函?
2019/06/24 职场文书
2019开业庆典剪彩仪式主持词!
2019/07/22 职场文书
php中配置文件保存修改操作 如config.php文件的读取修改等操作
2021/05/12 PHP