secp256k1如何使用
https://npm.taobao.org/package/secp256k1
这个即椭圆曲线加密算法算法,随机生成一个私钥然后通过椭圆曲线加密算法算法(ECC)得到一个公钥,且无法反向
然后再使用椭圆曲线签名算法(ECDSA)和私钥结合进行签名
Secp256k1是指比特币中使用的ECDSA(椭圆曲线数字签名算法)曲线的参数,并且在高效密码学标准(Certicom Research,http://www.secg.org/sec2-v2.pdf)中进行了定义。
Secp256k1为基于Fp有限域上的椭圆曲线,由于其特殊构造的特殊性,其优化后的实现比其他曲线性能上可以特高30%,有明显以下两个优点:
1)占用很少的带宽和存储资源,密钥的长度很短。
2)让所有的用户都可以使用同样的操作完成域运算。
即为一类比较安全的椭圆曲线
以太坊账户
要创建以太坊账户,只需要一个非对称加密密钥对——由不同的算法(例如RSA、ECC等)生成。以太坊使用椭圆曲线加密算法(ECC),ECC有多个参数用来调节速度和安全性,以太坊使用 secp256k1参数。
每个账户用一个地址表示。有了密钥之后,就需要生成地址。
从公钥生成地址的过程如下:
(1)生成公钥的keccak-256哈希。它将给出一个256位的数字。 
(2)丢弃前面的96位,即12字节。现在得到160位二进制数据,即20字节。 
(3)把地址编译成十六进制的字符串。最后将得到一个40字符的字 
节串,就是账户地址。
交易
交易是一个签名数据包,用于从一个账户向另一个账户或者向一个合约转以太币、调用合约方法或者部署一个新合约。
交易使用椭圆曲线数字签名算法(ECDSA)签名,ECDSA是一种基于ECC的数字签名算法。
交易包含:
- 信息接收者
 - 识别发起人及其意愿的签名
 - 要转账的以太币数量
 - 交易执行允许进行的计算资源最大值(叫作gas上限)
 - 交易发起人愿意为单位计算资源支付的费用(叫作gas价格)
 
如果交易目的是调用合约方法,则还包含输入数据。
如果其目的是部署合约,则可以包含初始化代码。 用交易所消耗的gas乘以gas价格计算得到交易费
安装:
npm install secp256k1 --save
使用:
const { randomBytes } = require('crypto');
const secp256k1 = require('secp256k1');
// or require('secp256k1/elliptic')
//   if you want to use pure js implementation in node
// generate message to sign
const msg = randomBytes();//随机生成一个数据
console.log(msg);
// generate privKey
let privKey
do {
  privKey = randomBytes();//随机生成一个私钥
  console.log(privKey);
} while (!secp256k1.privateKeyVerify(privKey));
// get the public key in a compressed format
const pubKey = secp256k1.publicKeyCreate(privKey);//根据私钥生成公钥
console.log(pubKey);
// sign the message
const sigObj = secp256k1.sign(msg, privKey);//然后进行签名
console.log(sigObj);
// verify the signature
console.log(secp256k1.verify(msg, sigObj.signature, pubKey));//核查签名是否正确
// => true
返回:
<Buffer 4a ae 6a 5b 7a 4a 8b 9e c0 aa 3c f9 a4 f3 1f bb>
<Buffer a0 4b 2b 2f b8 ee d3 d3 8f ea 6c fd 5a 1a c0 a2 c2 0c 3a e6 bf c1 >
<Buffer d1 f9 d6 7b b8 6e 6e 4e c9 e6 6c c5 0b ca 5e 3c cb 1a e4 0c >
{ signature:
<Buffer f9 f3 ff 0c a7 ea 4c 8d ed a1 2e 9a d4 cc b0 a6 e9 7f d6 dc 5a 4a 6b 6a 1b b6 e1 8a 7e ... >,
recovery: }
true
secp256k1如何使用的更多相关文章
- 以太坊的crypto模块--以太坊源码学习
		
以太坊的crypto模块 该模块分为两个部分一个是实现sha3,一个是实现secp256k1(这也是比特币中使用的签名算法). 需要说明的是secp256k1有两种实现方式,一种是依赖libsecp2 ...
 - nodeJS之crypto加密
		
前面的话 加密模块提供了 HTTP 或 HTTPS 连接过程中封装安全凭证的方法.也提供了 OpenSSL 的哈希,hmac, 加密(cipher), 解密(decipher), 签名(sign) 和 ...
 - ECC椭圆曲线详解(有具体实例)
		
前言 ECC英文全称"Ellipse Curve Cryptography" 与传统的基于大质数因子分解困难性的加密方法不同,ECC通过椭圆曲线方程式的性质产生密钥 ECC164位 ...
 - 以太坊go-ethereum签名部分源码解析
		
以太坊go-ethereum签名部分源码解析 golang标准库里的crypto/ecdsa椭圆曲线加密算法所提供的函数有: ecdsa.PublicKey结构体通过持有一个elliptic,Curv ...
 - 以太坊挖矿源码:clique算法
		
上文我们总结了以太坊最主要的共识算法:ethash算法,本文将重点分析以太坊的另一个共识算法:clique. 关键字:clique,共识算法,puppeth,以太坊地址原理,区块校验,认证结点,POA ...
 - 是否可能两个ETH私钥对应同一个地址
		
原提问在这里. 笔者在使用到neon-js中的私钥生成方法时发现其使用了getRandomValues方法来生成64字符长度的私钥,进而考虑到其随机性,若是调用足够多次,依然有可能生成两个完全一样的私 ...
 - Node.js 加密
		
稳定性: 2 - 不稳定; 正在讨论未来版本的 API 改进,会尽量减少重大变化.详见后文. 使用 require('crypto') 来访问这个模块. 加密模块提供了 HTTP 或 HTTPS 连接 ...
 - [区块链] 密码学——椭圆曲线密码算法(ECC)
		
今天在学椭圆曲线密码(Elliptic Curve Cryptography,ECC)算法,自己手里缺少介绍该算法的专业书籍,故在网上查了很多博文与书籍,但是大多数博客写的真的是...你懂的...真不 ...
 - The Ethereum devp2p and discv4 protocol Part II
		
描述 本文章主上下两篇 上篇:讲述以太坊devp2p与disc4节点发现协议 下篇:实践篇,实现如何获取以太坊所有节点信息(ip,port,nodeId,client) 正文 本片为下篇:实践篇,主要 ...
 
随机推荐
- LeetCode两数之和-Python<一>
			
下一篇:LeetCode链表相加-Python<二> 题目:https://leetcode-cn.com/problems/two-sum/description/ 给定一个整数数组和一 ...
 - javascript如何操作数组
			
说明 如需求:后台返回一个用户列表数组,该数组可能为空,最多只可能会有10个用户, 页面中A,B两处展示用户列表,B处不管如何都会展示返回的所有用户,A处需要展示10个用户,不足10个展示默认用户, ...
 - 【读书笔记】iOS-PhoneGap
			
以前,用PhoneGap平台创建的应用在提交到AppStore中的时候可能会遇到一些问题,不过PhoneGap 0.8.0版本已经很好地解决了这个问题,而且苹果公司也允许将通过PhoneGap构建的应 ...
 - css制作表格
			
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
 - IDEA项目搭建九——MybatisPlus多数据库实现
			
一.简介 MybatisPlus中引用多数据库时,传统的配置就失效了,需要单独写配置来实现,下面就说一下具体应该如何操作 二.引入MybatisPlus多数据源配置 还是先看一下我的项目结构,Mode ...
 - SVN SVN合并(Merge)与拉取分支(Branch/tag)操作简介
			
SVN合并(Merge)与拉取分支(Branch/tag)操作简介 合并(Merge) 例子:把对feature_branch\project_name_v3.3.7_branch的修改合并到deve ...
 - Jmeter 测试计划元素详解
			
Jmeter 测试计划元素详解 by:授客 QQ:1033553122 由于篇幅问题,采用链接分享的形式,烦请复制以下网址,黏贴到浏览器中打开,下载 http://pan.baidu.com/s/1n ...
 - Java网络编程--InetAdress类
			
一.地址 java.net包中的InetAddress 类对象含有一个Internet主机地址的域名和Ip地址 www.sina.com.cn/202.108.35.210 二.获取地址 1.获取In ...
 - Android 高德地图定位
			
创建Key 打开高德开发平台 → 我的应用 → 创建应用 → 创建新Key 说明: 1.发布版安全码获取:用自己的签名打包成apk安装软件,用SHA1工具查看 2.调试版安全码获取: 直接运行安装软件 ...
 - Flutter 安装
			
都说程序猿学习是不分平台的,做了一辈子的Xaml,也想看看现在最牛逼的移动技术. 看了看Google 的Flutter,好像很牛逼,不怎么需要Android和IOS基础(应该还是要的), 不过现在是B ...