在密码学中,可验证随机函数是一种随机数生成器,可以通过加密手段来验证随机性。可验证的随机数对许多区块链应用来说都是不可或缺的要素,因为这类随机数具有防篡改性和不可预测性,可以用来打造刺激的游戏体验,铸造罕见的NFT,并保障公平的结果。
本文将讨论什么是可验证随机函数,研究随机数在区块链上的应用,以及智能合约开发者如何利用Chainlink可验证随机函数在dApp中获得安全的随机数来源。
什么是可验证随机函数?
可验证随机函数是一种加密函数,基于数据输入生成伪随机数并附上一份证明,任何人都可以对其进行验证。
VRF的数据输入通常包含一对公钥和私钥以及一个seed。公钥和私钥是生成的,而seed则是选择的。将这些数值一起输入VRF,用私钥和seed来生成随机数。然后,VRF会生成一个随机数以及一份证明。最关键的一步是生成证明,因为用户可以通过证明来验证函数。而将私钥保密则可以确保随机数无法被预测。
可验证随机函数的关键特质都写在了它的名字里:
孙宇晨向Curve创始人地址转入200万枚USDT,Curve创始人已偿还713万FRAX债务:8月1日消息,链上数据显示,孙宇晨向Curve创始人地址转入200万枚USDT。之后Curve创始人向孙宇晨地址转入500万枚CRV。Curve创始人Michwill再次进行还款操作,近两小时累计还款713万枚FRAX。[2023/8/1 16:11:35]
可验证——任何人都可以验证VRF生成的随机数是否有效,只需要查看证明并验证哈希计算结果是否正确即可。只有持有VRF私钥的人才能进行哈希运算,而任何持有公钥的人都可以验证哈希运算结果。
随机——对于不知道seed或不持有私钥的人来说,VRF输出的结果完全不可预测且概率均匀分布,没有任何规律可循。VRF输出的每个结果都拥有同样的概率,并使用seed和私钥,以独特的方式生成随机数。
函数——VRF使用数学算法来生成随机数以及证明。VRF将seed隐藏起来,以保障其不可预测性;同时,将随机数证明公开,以供所有人查看和验证。
VRF的发展历史
Matic或向投资者提供以单价0.7美元将已锁定Token赎回为现金的选择权:6月11日消息,Twitter用户@0xSisyphus发文称,Matic向许多投资者提供了一种选择权,即当Token价格跌破该水平线时以单价0.7美元将投资者已锁定的Token赎回为现金。0xSisyphus同时询问该机制的工作原理。随后DeFi播客MarketCapping主持人@SmallCapScience回复推文并释出相关条款:
最小购买头寸5万美元,最大20万美元。根据条款和条件,在公司收到购买者签名页后向购买者交付Token数量和总购买价格,具体为:50%的Token在生效日期后12个月解锁;25%的Token在生效日期后18个月解锁;25%的Token在生效日期后24个月解锁。所有Token将在条款生效日期后的24个月内交付给买方。即买方可以以14天的加权平均价格购买MATIC,授予期2年,解锁期1年。在交易中,买方有Token下跌保护。如果一年后Token价格下降,买方可以选择取回现金。[2023/6/11 21:29:04]
可验证随机函数这个概念是在1999年由知名计算机科学家和数学家SilvioMicali、MichaelRabin以及SalilVadhan在论文中提出的。值得一提的是,SilvioMicali后来创建了Algorand区块链,Algorand在共识机制中也使用了VRF。?
V神:现在不是推出加密ETF的最佳时机:金色财经报道,以太坊创始人Vitalik Buterin认为现在不是推出加密ETF的最佳时机。针对美国证券交易委员会迟迟未批准现货交易比特币ETF,Buterin评论说这不是世界末日,没有这样的产品可能会带来看不见的好处。我认为我们不应该热情地追逐大型机构资本。我很高兴很多交易所交易基金都被推迟了。在我们得到更多关注之前,生态系统需要时间成熟。
Buterin 还提出了他对加密领域监管可能性的看法,Buterin表示:允许加密空间在内部自由行动但使加密项目更难进入主流的监管比侵入加密内部工作方式的监管要好得多。[2022/12/4 21:22:10]
之后,VRF技术出现了一系列关键突破。2005年,YevgeniyDodis和AleksandrYampolskiy使用了抗碰撞哈希函数实现了更短的证明和密钥,因此提升了VRF的效率,并推动了这项技术的发展。2015年,DennisHofheinz和TiborJager使用椭圆曲线加密技术开发了可验证安全性的VRF。2019年,NirBitansky提出了VRF可以用一般原语构造,而不用简单的代数构造。如今许多VRF方案都建立在这些创新之上。
Messari:Maple Finance发放超16亿美元贷款,仅产生1000万美元单笔违约:10月19日消息,区块链分析公司Messari发布推文称,机构借贷协议Maple Finance自推出以来,通过该协议产生了超过16亿美元的贷款,仅在2022年第二季度产生1000万美元的单笔违约。[2022/10/19 17:32:50]
2020年,研究者提出了一种使用Lattice加密的VRF方案。这个方案的安全性足以抵御量子计算机发起的攻击,这意味着VRF将在未来仍是一项重要技术。
VRF的应用场景
大多数RNG都无法生成可以通过加密技术进行验证的随机数,因此这类RNG容易受到操纵,导致其应用场景受限。VRF如果能保障随机数的安全性,就可以解锁一系列关键的用例,其中包括:
网络安全——使用VRF保障域名系统消息传输的安全性。
零知识技术——VRF可以用来打造零知识证明和零知识数据库。
非交互式抽奖系统——VRF可以为抽奖游戏保障公平、可验证且高效的结果。
俄罗斯国家杜马金融市场委员会主席呼吁将加密货币跨境支付合法化:金色财经报道,俄罗斯国家杜马金融市场委员会主席Anatoly Aksakov认为,有必要为加密货币的跨境结算提供一个监管框架。俄罗斯议会下院预计将在今年秋天审查与加密货币有关的立法草案,包括一项新的“数字货币”法案,而Aksakov一直是积极参与者。
本周早些时候,俄罗斯财政部和中央银行同意,在目前的情况下,对俄罗斯来说,“不可能没有加密货币的跨境结算”。俄罗斯商业日报Kommersant和RIA Novosti通讯社援引Aksakov的话说,确定在跨境结算中使用加密货币的法律界限是一项重要任务。他还强调需要确保进入这个市场的人得到当局的确认。(Bitcoin.com)[2022/9/9 13:19:21]
可验证的交易托管机制——VRF可以支持自动托管服务,保障用户的匿名性。
区块链和智能合约——VRF已经成为了去中心化协议和应用重要的组成部分。
区块链中的VRF
包括Algorand、Cardano、InternetComputer和Polkadot在内的许多L1区块链都在共识机制中使用了VRF来随机选择出块节点。?
另外,区块链智能合约开发者在开发应用时也需要随机数。然而,由于区块链网络具有高确定性,链上应用往往无法获得安全的随机数生成器。使用链上区块哈希生成随机数有可能被区块链矿工/验证者操控,他们可以放弃对他们不利的区块,重新“掷色子”,以改变随机数。而链下随机数则缺乏透明性,而且无法验证随机数是否公正且没有受到数据源或节点的操控。
可以利用链上生成随机数方案的漏洞谋取私利。
稳健的随机数生成方案意味着随机数的公平性可以得到验证,所有参与者都拥有同样的概率,并且攻击者不太可能通过预测随机数来操纵智能合约。
ChainlinkVRF
ChainlinkVRF?是公平、可验证的RNG,可以满足上述需求,为智能合约提供具有加密证明的安全随机数,无法被预言机节点、用户或开发团队篡改。
ChainlinkVRF可以为开发者带来以下好处:?
不可预测性——ChainlinkVRF无法被预测。由于在请求随机数时无法得知区块数据,因此任何人都无法通过预测随机数来提高自己的成功概率。
公平性——ChainlinkVRF非常公平公正,因为随机数是均匀分布的,所有数字都有同样的概率被选中。
随机性——ChainlinkVRF的随机性可以得到验证,因为其使用区块哈希作为seed来生成随机数,而区块哈希无法提前预知。
防篡改性——ChainlinkVRF具有防篡改性,任何人,包括预言机、外部方或开发团队,都无法操纵随机数生成流程。
ChainlinkVRF是用户和区块链之间的抽象层,可以帮助智能合约开发者访问安全的随机数来源。
ChainlinkVRF采用了开源代码和加密技术,生成防篡改的随机数,用户可以验证随机数的真实性。
ChainlinkVRF采用了Goldberg的可验证随机函数,详情请查看这篇论文。ChainlinkVRF会针对每一个随机数请求生成一个或多个随机数,并附上一份随机数的加密证明。这份证明会被发布到链上并在链上得到验证,验证通过后才会使用随机数。
ChainlinkVRF的应用场景
ChainlinkVRF目前正在为Web3生态中的众多应用提供安全的链上随机数来源,其中包括GameFi、DeFi以及NFT等项目。
ChainlinkVRF的应用场景包括:
为NFT分配随机属性——ChainlinkVRF可以用来铸造特殊的NFT。比如,AxieInfinity?使用ChainlinkVRF为每个OriginAxie赋予随机属性。
公平地分配罕见NFT——ChainlinkVRF可以证明NFT是公平分配的,且证明可以得到验证。比如,BoredApeYachtClub?使用ChainlinkVRF向BAYCNFT持有者随机分配变异血清NFT。
游戏结果无法预测——开发者可以利用随机数打造出更好玩的区块链游戏。比如,Blockmine使用ChainlinkVRF在NextCard游戏中随机抽取卡牌。
公平地选出参与者——发放热门活动门票,抽取奢侈品预售的买家,以及选出热门公开发售活动的参与者。比如,Centaur使用ChainlinkVRF选出链上公开发售活动的参与者。
随机选出中奖者——ChainlinkVRF可以让用户验证中奖者的筛选流程是否公平公正。比如,PoolTogether是一个无损储蓄游戏,将用户存款放在一个资金池中,并每天和每周展开抽奖,将池子的收益随机分配给中奖者。
PoolTogether利用ChainlinkVRF随机选出无损储蓄游戏的中奖者。
总结
ChainlinkVRF是区块链行业领先的安全随机数生成器,为智能合约和链下系统提供可验证且防篡改的随机数来源。
ChainlinkVRF通过加密技术为开发者保障随机数的安全性和可验证性,帮助他们打造出更加开放、可访问且防篡改的系统。ChainlinkVRF和智能合约将实现区块链的最终愿景,基于加密事实打造出更加强大的算法系统,取代当前基于信任的薄弱系统。
如果你是一名开发者,并希望快速将智能合约连接至ChainlinkVRF,请查看开发者文档并加入我们在Discord上的技术讨论群。如果你希望安排一次电话会议具体讨论集成事宜,请点击此处联系我们。
扩展阅读
《一文读懂智能合约》
《一文读懂区块链预言机》
《Solidity语言的随机数生成》
《如何在NFT中获得随机数》
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。