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. zz错误集锦

    1.csp-s模拟测试63 T1 2e8的数组开bitset会ce,开bool就可以了,bool一位占一个字节,不是四个字节 2.csp-s模拟测试65 T2 把用vector存图改成前向星,就A了, ...

  2. 1.go语言入门

    1.Go语言中文网,选择相应版本(32位或64位)下载 https://studygolang.com/dl, 2.解压到一个任意文件夹 3.配置环境变量 cmd命令行输入go version查看当前 ...

  3. sc命令创建和删除服务

    安装服务 sc create 服务名 binPath= "C:\Users\Administrator\Desktop\win32srvDemo\win32srvdemo\Debug\win ...

  4. Enum.GetValues(),返回System.Array的一个实例

    Array enumData = Enum.GetValues(e.GetType()); Console.WriteLine("This enum has {0} members.&quo ...

  5. 禁用,移除 WPF window窗体系统操作SystemMenu

    public static class SystemMenuManager { [DllImport("user32.dll", EntryPoint = "GetSys ...

  6. C# 嵌套循环

    一.简介 嵌套循环:while.for和do...while循环使用一个或者多个嵌套. 二.实例 输出九九乘法表(循环的嵌套) //乘法口诀 for (int i = 1; i <= 9; i+ ...

  7. laravel he stream or file "..laravel-2019-02-14.log" could not be opened: failed to open stream: Permission denied

    错误:The stream or file "/var/www/jianshu/storage/logs/laravel-2019-02-14.log" could not be ...

  8. Flask笔记:cookie

    在网站中,HTTP请求是无状态的:第一次请求成功后,第二次请求时服务器依然不知道这次请求的所属用户是谁.为了解决这个问题,在第一次请求成功后,服务器会生成并返回对应的cookie信息给浏览器,而浏览器 ...

  9. jmeter入门操作 = 接口

    1.没安装工具的朋友,不熟悉菜单插件使用的朋友,请先看:https://www.cnblogs.com/beile/p/11007754.html 2.开始调用http请求 测试地址:http://h ...

  10. java斐波那契数列的顺序输出

    斐波那契数列,即1.1.2.3.5......,从第三个数开始包括第三个数,都为这个数的前两个数之和,而第一第二个数都为1. 下面是java输出斐波那契数列的代码: import java.util. ...