VRF(可验证随机函数)快速理解

理解VRF之前,需要先理解带秘钥的哈希函数,和传统的哈希函数不同,带秘钥的哈希函数在计算HASH数值的时候引入了一个不公开的秘钥,这样为从明文到HASH数值计算之间添加了一定的难度,这个难度就是由秘钥引入的。我们简单的定义一个带秘钥的HASH函数为如下的形式:

hash_value=HASH(pri_key, message)

那么当我们拥有了计算出来的hash_value和数据message,我们需要知道pri_key才可以验证hash_value是否由message通过HASH函数生成。一般我们知道秘钥pri_key对于我们信息安全的重要性。因此现在引出来如下的问题:

  • 对外只暴露pri_key对应的pub_key
  • 在不暴露pri_key的情况下,验证hash_value和message之间是匹配的

为了实现上面的目的,于是就有了可验证随机函数VRF,现在我们一步一步看其实如何工作的:

step 1 : 生成一对公私钥,分别为pri_key和pub_key
step 2 :计算hash_value=VRF_HASH(pri_key, message)
step 3 :计算proof_value=VRF_PROOF(pri_key, message)
step 4 : 现在将hash_value和proof_value提供给验证者
step 5 : 验证者拿到hash_value和proof_value计算hash_value=VRF_P2H(proof_value)
step 6 : 如果step5成功,则验证者计算VRF_VERIFY(pub_key, message, proof)
step 7 : 如果step6返回true则表示验证通过,否则验证失败

梳理一下我们可以这样理解,首先验证proof是否是由message生成的,然后验证proof是否可以就散出hash_value,这样我们就可以推理出hash_value是否由message生成,并且能找到过程中proof是否出现问题。过程中三个关键函数

  • VRF_HASH
  • VRF_PROOF
  • VRF_VERIFY

就会我们事先VRF的关键

  • 7
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值