可验证随机数VRF的一种实现

本文探讨了IETF VRF方案,介绍如何通过椭圆曲线上的多项式运算,结合私钥和随机数生成唯一且可验证的随机数。VRF保证了给定的消息和私钥对应一个确定的输出,而传统的签名算法不具备这种特性。文章详细阐述了多项式实例化和应用到VRF的过程,并提到了不同基点的选择对于生成随机数的影响。
摘要由CSDN通过智能技术生成

本文简单分析一下ietf-vrf方案的实现原理。
所谓VRF就是指给定一个消息和一个私钥,可以计算出一个唯一确定的值,这个值唯一确定且不可预测,且可以验证。
传统的签名算法不具有唯一确定的特性,私钥持有者可以计算出多个合法解。

前置技能树:需了解椭圆曲线的基本运算法则。

1. 简单的多项式:

t = ( r − s ∗ k )   m o d   p t = (r - s * k) \bmod p t=(rsk)modp
这个等式就是普通的整数运算,r,t,s,k,n均为大整数,p为常量。
k为私钥,r为随机数,二者不可泄露。

2. 椭圆曲线上的多项式

把上面的等式和椭圆曲线的基点 G G G相乘,可以得到下面的等式:
T = t ∗ G = ( r − s ∗ k ) ∗ G = r ∗ G − s ∗ k ∗ G = R − s ∗ K \begin{aligned} T &= t*G \\ &= (r - s * k)*G \\ &= r*G - s*k*G \\ &= R-s*K \end{aligned} T=tG=(rsk)G=rGskG=RsK

小写字母为整数,对应的大写字母为该整数映射到曲线上的点

当选取不同的基点 G x G_x G<

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值