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'))//compressedpublicKey = curvePt.getEncoded(true) //true forces compressed public keyconsole.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 keyconsole.log("pubkeyHash:" + pubkeyHash.toString('hex')) // address of compressed public keyconsole.log("压缩地址:" + cs.encode(pubkeyHash, 0x0)) //<-- 0x0 is for public addresses//这里还缺失校验和Base58编码console.log(cs.encode(privateKey, 0x80)) //<--- 0x80 is for private addressesconsole.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

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

vue-cli项目中使用bootstrap步骤详解

AngularJs如何防止XSS攻击

AngularJS使用Filter自定义过滤器案列详解

以上就是Node.Js如何实现比特币地址的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2766979.html

(0)
上一篇 2025年3月8日 11:29:36
下一篇 2025年3月8日 11:29:41

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • vue.js+element-ui实现树形结构

    这次给大家带来vue.js+element-ui实现树形结构,vue.js+element-ui实现树形结构的注意事项有哪些,下面就是实战案例,一起来看一下。 由于业务需要,要求实现树形菜单,且菜单数据由后台返回,在网上找了几篇文章,看下来…

    2025年3月8日
    200
  • JS装饰器函数使用详解

    这次给大家带来JS装饰器函数使用详解,JS装饰器函数使用的注意事项有哪些,下面就是实战案例,一起来看一下。 在 ES6 中增加了对类对象的相关定义和操作(比如 class 和 extends ),这就使得我们在多个不同类之间共享或者扩展一些…

    编程技术 2025年3月8日
    200
  • JS实现html中placeholder带提示效果

    这次给大家带来JS实现html中placeholder带提示效果,html中placeholder带提示效果的注意事项有哪些,下面就是实战案例,一起来看一下。z 如何通过js实现html的placeholder属性效果呢 我们需要这样做: …

    2025年3月8日
    200
  • JS实现文件拖拽步骤详解

    这次给大家带来JS实现文件拖拽步骤详解,JS实现文件拖拽的注意事项有哪些,下面就是实战案例,一起来看一下。 本文实例为大家分享了javascript实现文件拖拽事件的具体代码,供大家参考,具体内容如下 1.效果图: 2.源码 #p1 { w…

    2025年3月8日
    200
  • vue.js树形控件使用详解

    这次给大家带来vue.js树形控件使用详解,vue.js树形控件使用的注意事项有哪些,下面就是实战案例,一起来看一下。 实现原理 修改了element-ui源码,把源码里面的tree模块提取出来 然后修改element自带checkbox等…

    2025年3月8日
    200
  • JS新手易错点整理

    这次给大家带来JS新手易错点整理,JS新手易错点的注意事项有哪些,下面就是实战案例,一起来看一下。 1.前言 这段时间,金三银四,很多人面试,很多人分享面试题。在前段时间,我也临时担任面试官,为了大概了解面试者的水平,我也写了一份题目,面试…

    2025年3月8日 编程技术
    200
  • JS中new()实现了哪些功能?

    这次给大家带来JS中new()实现了哪些功能?,使用JS中new()的注意事项有哪些,下面就是实战案例,一起来看一下。 前言 和其他高级语言一样 javascript 中也有 new 运算符,我们知道 new 运算符是用来实例化一个类,从而…

    2025年3月8日
    200
  • JS发送json格式POST请求

    这次给大家带来JS发送json格式POST请求,JS发送json格式POST请求的注意事项有哪些,下面就是实战案例,一起来看一下。 登录后复制 一、获取url所有参数值 function US() {var name, value;var …

    编程技术 2025年3月8日
    200
  • controller接收js传递json参数

    这次给大家带来controller接收js传递json参数,controller接收js传递json参数的注意事项有哪些,下面就是实战案例,一起来看一下。 Spring MVC在接收集合请求参数时,需要在Controller方法的集合参数里…

    编程技术 2025年3月8日
    200
  • js怎么传递数组参数

    这次给大家带来js怎么传递数组参数,js传递数组参数的注意事项有哪些,下面就是实战案例,一起来看一下。 传递参数传递字符串,所以要把数组转换为字符串, var arr=[1,23,34,5];var str = arr.toString()…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论