P256 VRF实现及其改造


P256对应的椭圆曲线是:

\[y^2=x^3-3x+b
\]

公式推导

假设k是私钥,G是公钥(\(g^k\))

m:表示已知的公共信息,比如当前要出的块号100

H1:把任意信息映射到曲线上的点

思路也很简单,将Hash(m)(注意是256位hash)作为曲线上的X,然后带入上述椭圆曲线公式,求出相应的Y即可.

H2: 映射任意信息为(1,q)

这个也很简答,就是Hash(...)%q即可.

计算随机数

\[h=H_1(m)
\\
v=VRF_k(m)=h^k
\]

这就是所谓的可验证随机数,那么怎么让他可验证呢?

随机数的proof

随机生成一个r,然后计算

\[s=H_2(g,h,G,v,g^r,h^r)
\\
t=r-sk (mod p)
\]

然后把(v,s,t)一起打包发给验证方,

如何验证

上述信息中已知的有:

  1. g: 曲线公共参数
  2. h: H1(m) ,因为m已知,Hash方法也是已知
  3. G: 公钥
  4. v: 随机数,验证方明文收到
  5. t: 验证法明文收到
  6. s: 验证法明文收到

生成gr,hr

\[g^r
=g^{t+ks}
=g^t \cdot g^{ks}
=g^t \cdot {g^k}^s
=g^t \cdot G^s
\]

\[h^r
=h^{t+ks}
=h^t \cdot h^{ks}
=h^t \cdot {h^k}^s
=h^t \cdot v^s
\]

虽然验证人不知道k,也不知道r,但是知道h,g,G,v,s,t所以他可以计算出\(s2=H_2(g,h,G,v,g^t \cdot G^s,h^t \cdot v^s)\)

然后验证s2是否和s相等,如果相等,那就是k持有人按照规则计算出的随机数

VRF优点

  1. 验证人只知道m,在k持有人没有广播之前不知道随机数是什么
  2. k持有人无法伪造随机数,否则过不了验证人.

    这就是所谓的随机数(除了k之外,其他任何人事先不知道)

    可验证(知道k公钥的任何人都知道k生成的随机数是否合规)

针对S256曲线的改造

谷歌给出的例子是针对P256的,但是无论是比特币还是以太坊及其衍生链,采用的都是S256曲线. 那么经过简单的改造就可以在S256曲线上使用VRF

1. 使用S256曲线

将使用的P256直接换成S256

	//curve  = elliptic.P256()
curve=btcec.S256()
params = curve.Params()

2. 修改H1

前面提到H1实际上是把任意信息映射到曲线上的点,P256方案采用的曲线是

\(y^2=x^3-3x+b\),而S256曲线是\(y^2=x^3+b\),稍微有一些区别,因此计算\(y^2\)的方法要修改

// Use the curve equation to calculate y² given x.
// only applies to curves of the form y² = x³ - 3x + b.
func y2(curve *elliptic.CurveParams, x *big.Int) *big.Int { // y² = x³ - 3x + b
x3 := new(big.Int).Mul(x, x)
x3.Mul(x3, x) //threeX := new(big.Int).Lsh(x, 1)
//threeX.Add(threeX, x)
//
//x3.Sub(x3, threeX)
x3.Add(x3, curve.B)
x3.Mod(x3, curve.P)
return x3
}

3. 替换点乘

P256代码中的ScalarMult和ScalarBaseMult都是使用的params上的方法,这个方法是在go标准库中的.标准库针对的椭圆曲线并不是S256,而是\(y^2=x^3+b\),因此不能使用,要替换成curve上的想用方法.

把params.ScalarBaseMult替换成curve.ScalarBaseMult

把params.ScalarMult替换成curve.ScalarMult

参考文献

google VRF

spectrum 基于S256的VRF

P256 VRF实现解读的更多相关文章

  1. Spark源码的编译过程详细解读(各版本)

    说在前面的话   重新试多几次.编译过程中会出现下载某个包的时间太久,这是由于连接网站的过程中会出现假死,按ctrl+c,重新运行编译命令. 如果出现缺少了某个文件的情况,则要先清理maven(使用命 ...

  2. JWT全面解读、使用步骤

    JWT全面解读JWT全面解读前言JWT基本使用在pom.xml引入java-jwt示例如下概念介绍JWT消息构成头部playload标准中注册的声明 (建议但不强制使用)自定义数据签名signatur ...

  3. Spark源码的编译过程详细解读(各版本)(博主推荐)

    不多说,直接上干货! 说在前面的话   重新试多几次.编译过程中会出现下载某个包的时间太久,这是由于连接网站的过程中会出现假死,按ctrl+c,重新运行编译命令.  如果出现缺少了某个文件的情况,则要 ...

  4. SDWebImage源码解读之SDWebImageDownloaderOperation

    第七篇 前言 本篇文章主要讲解下载操作的相关知识,SDWebImageDownloaderOperation的主要任务是把一张图片从服务器下载到内存中.下载数据并不难,如何对下载这一系列的任务进行设计 ...

  5. SDWebImage源码解读 之 NSData+ImageContentType

    第一篇 前言 从今天开始,我将开启一段源码解读的旅途了.在这里先暂时不透露具体解读的源码到底是哪些?因为也可能随着解读的进行会更改计划.但能够肯定的是,这一系列之中肯定会有Swift版本的代码. 说说 ...

  6. SDWebImage源码解读 之 UIImage+GIF

    第二篇 前言 本篇是和GIF相关的一个UIImage的分类.主要提供了三个方法: + (UIImage *)sd_animatedGIFNamed:(NSString *)name ----- 根据名 ...

  7. SDWebImage源码解读 之 SDWebImageCompat

    第三篇 前言 本篇主要解读SDWebImage的配置文件.正如compat的定义,该配置文件主要是兼容Apple的其他设备.也许我们真实的开发平台只有一个,但考虑各个平台的兼容性,对于框架有着很重要的 ...

  8. SDWebImage源码解读_之SDWebImageDecoder

    第四篇 前言 首先,我们要弄明白一个问题? 为什么要对UIImage进行解码呢?难道不能直接使用吗? 其实不解码也是可以使用的,假如说我们通过imageNamed:来加载image,系统默认会在主线程 ...

  9. SDWebImage源码解读之SDWebImageCache(上)

    第五篇 前言 本篇主要讲解图片缓存类的知识,虽然只涉及了图片方面的缓存的设计,但思想同样适用于别的方面的设计.在架构上来说,缓存算是存储设计的一部分.我们把各种不同的存储内容按照功能进行切割后,图片缓 ...

随机推荐

  1. usb设备在sysfs中的命名规范

    "root-hub的编号"-"设备(或者hub)插入的端口号"[."设备(或者hub)插入的端口号"]:"USB设备配置号&quo ...

  2. Win10导出查看删除已安装的证书

    1.控制面板中搜索证书 2.点击管理用户证书或管理计算机证书,即可查看所有安装好的证书 3.双击即可查看证书,右键证书即可删除无效的证书 4.搜索证书,比如百度用到的根证书是GlobalSign Ro ...

  3. jQuery 源码分析(四) each函数 $.each和$.fn.each方法 详解

    $.each一般用来遍历一个数组或对象,$.fn.each()就是指jQuery实例可以执行的操作(因为$.fn是jQuery对象的原型) $.each用来遍历一个数组或对象,并依次执行回掉函数,最后 ...

  4. [KMP]一本通(http://ybt.ssoier.cn:8088) 1698:字符串匹配

    字符串匹配 [题目描述] 对于一个字符集大小为C的字符串pp,可以将任意两个字符在p中的位置进行互换,例如p=12321,交换1.21.2得到21312,交换1.4得到42324,交换可以进行任意次. ...

  5. ASP.NET Core: BackgroundService停止(StopAsync)后无法重新启动(StartAsync)的问题

    这里的 BackgroundService 是指: Microsoft.Extensions.Hosting.BackgroundService 1. 问题复现 继承该BackgroundServic ...

  6. python3模块

    一.sys模块 import sys #print(sys.path) #打印环境变量 #print(sys.argv) print(sys.argv[3]) Sys.argv[ ]其实就是一个列表, ...

  7. Comet OJ-2019国庆欢乐赛

    国庆玩的有点嗨,开学了补题. A轰炸平面镇魂曲 题目描述 虹村万泰是一位二维世界的替身使者,他的替身 "轰炸平面镇魂曲" 能产生一条直线分割整个平面. 一开始,平面上有一个矩形,其 ...

  8. .NET Core 收徒,有缘者,可破瓶颈

    最近感悟天命,偶有所得,故而打算收徒若干,以继吾之传承. 有缘者,可破瓶颈,职场巅峰指日可待. 入门基本要求: 1.工作经验:1年或以上. 2.拜师费用:3999元(RMB). 传承说明: 1.收徒人 ...

  9. 开发技术--Python核心技术B

    开发|Python核心技术B B篇,主要介绍Python的自定义函数,匿名函数,面向对象,模块化. 由于不涉及基础的知识,我会将重难点加以解释. 前言 目前所有的文章思想格式都是:知识+情感. 知识: ...

  10. JavaScript 数据类型转换表

    下表显示了将不同的JavaScript值转换为Number,String和Boolean的结果: 原始值 转换为Number 转换为String 转换为Boolean false 0 "fa ...