宇宙链 宇宙链
Ctrl+D收藏宇宙链
首页 > USDC > 正文

如何使用Chainlink VRF在Solidity中生成随机数?

作者:

时间:1900/1/1 0:00:00

Solidity中无法原生地完成随机数生成。要在区块链上生成一个真正可验证的随机数,智能合约必须将种子发送到像预言机这样的链外资源,而预言机必须将随机数连同可验证的证明一起返回给智能合约,证明随机数是使用种子生成的。随着ChainlinkVRF现已在Ethereum主网上线,开发者可以在Solidity中以安全可靠、可验证的方式轻松生成随机数。在这篇技术文章中,我们将向您展示如何使用ChainlinkVRF在Solidity中生成随机数。在您的智能合约中生成安全随机数的例子可以在Chainlink文档中找到。这里有一个Remix上在Kovan测试网生成区块链随机数的例子,供现在想测试的人使用。只要记得按照请求和接收方法,用LINK转账到你的智能合约就可以了。ChainlinkVRF的高级概述

法律专家:Mango Markets案例会影响DAO未来如何实施其法律和治理结构:2月4日消息,加拿大律师事务所McMillan LLP的合伙人Benjamin Bathgate表示,针对所谓的Mango Markets漏洞利用者Avraham Eisenberg的诉讼可能会影响DAO未来如何实施其法律和治理结构。Bathgate表示,在很多情况下,DAO只是用户的集合,这是一个用户社区,也许有一个核心贡献者负责编码。管理Mango Market DAO的怀俄明州有限责任公司Mango Labs正在寻求收回剩余的4700万美元。然而,Bathgate表示,Mango Labs的诉讼不太可能成功,到那时可能会为DAO生态系统敲响警钟。

此前报道,Mango Markets攻击者Avraham Eisenberg在纽约美国地方法院第一次听证会上放弃保释。目前,Avraham正被Mango Labs起诉,要求赔偿剩余的4700万美元,他被指控犯有商品欺诈、商品操纵和电汇欺诈三项刑事罪。[2023/2/4 11:46:50]

ChainlinkVRF是一个为智能合约设计的公平的可验证的随机性来源。Solidity开发人员可以使用它作为防篡改的随机数生成器,为依赖不可预测结果的Ethereum应用构建安全可靠的智能合约。在Solidity中使用ChainlinkVRF生成随机数的第一步是确定一个种子。选择一个难以被影响或预测的种子极为重要。如果有人能够影响或预测种子,理论上他们可以尝试与执行随机性请求的预言机节点串通,产生一个对自己有利的结果。正因为如此,建议不要使用来自区块链状态的值,如区块高度或区块时间戳。然后,这个种子会以请求的方式发送到Chainlink预言机。然后,预言机会用给定的种子生成一个伪随机数,并将结果返回给智能合约,一同返回的还有一个加密证明,用来验证随机数是使用种子生成的。这种加密证明是通过公钥加密技术创建的,这是区块链技术中广泛使用的技术。重要的是,结果可以被验证,避免矿工或预言机等参与者为了自己的利益而影响随机数的结果。这是对ChainlinkVRF工作方式的高级概述。关于底层技术实现的更多细节可以在我们对ChainlinkVRF的介绍中找到。然而,作为开发者,除了获取种子,然后向Chainlink预言机创建一个请求之外,你不需要担心任何事情。创建消费者合约如何在Solidity智能合约中获得一个随机数,我们应该首先从ChainlinkVRFConsumerBase合约中继承。消费者合约还应该包含存储随机数结果的变量,用于生成随机性的公钥哈希,以及为完成请求而付给预言机的费用。

美国国会研究人员:立法者需考虑数字货币立法将如何影响美元:金色财经报道,美国国会研究服务局在其题为“美元作为世界主要储备货币”的报告中称,不断增长的加密货币空间的影响并没有引起任何与美元地位有关的重大担忧。报告承认,尽管“加密货币仍然是一个小而动荡的利基市场”,但中央银行数字货币(CBDC)正在兴起。报告指出,迄今为止,尚无证据表明美元已脱离主要储备货币。但是,国会不妨考虑一下包括制裁和数字货币在内的一系列政策领域的立法将如何影响美元。[2020/12/22 16:03:19]

接下来,在构造函数中,我们应该初始化ChainlinkVRF协调器。调用VRFConsumerBase函数,传入VRF协调器的地址和给定环境的Chainlinktoken的地址作为参数。还需要设置keyHash变量,这是生成随机性的公钥。这些的环境特定值可以在ChainlinkVRF文档的合约地址部分获得。最后,我们需要设置LINKtoken的支付金额。对于Kovan测试环境,它是0.1个LINK。

直播|李慧:显卡矿池如何杀出重围:金色财经 · 直播主办的《 币圈 “后浪” 仙女直播周》第8期14:00准时开始,本期“后浪”仙女蜘蛛矿池 市场总监 李慧将在直播间聊聊“显卡矿池如何杀出重围”,感兴趣的朋友扫码移步收听![2020/7/11]

接下来,我们重写合同中的两个函数`getRandomNumber`和`fulfillRandomness`。`getRandomNumber`函数应该把种子作为输入参数,并且调用VRFConsumerBase中的`requestRandomness`函数,传递keyHash,费用金额和给定的种子作为参数。

声音 | 复旦杨洁萌:Libra落地最大挑战来自于如何应对监管:9月25日晚,第83期“金融学术前沿”报告会在复旦大学智库楼106会议室举行。复旦发展研究院金融研究中心(FDFRC)主任孙立坚教授研究团队成员杨洁萌发布了题为“Libra乌托邦与中国法定数字货币的机遇”的报告。杨洁萌表示,Libra和传统支付系统比,满足不同参与方的诉求,帮助账户方做大支付、汇款,让收款方降低交易成本,也让传统机构观察、应对创新的手段。具体来说,具有三大优势:1、低操作成本:区块链取代人工对账带来效率提高,差错减少;2、低交易成本:Libra体系内交易无需向中心化机构代理机构付费;3、低保证金降低成本:账本实时同步加强机构间公信,减少保证金要求,降低保证金带来的额外成本。Libra也依然面临着四大风险:各国面临的监管要求不同;反风险;资金安全和信息安全;监管政策不确定风险。因此,Libra虽然抱有非常美好的幻想,但离真正落地还有诸多挑战,最大的挑战来自于如何应对监管,还有包括隐私问题、挤兑风险问题等诸多问题,还处于乌托邦的阶段。(复旦发展研究院微信公众号)[2019/9/30]

执行时,这个函数将请求发送到给定的VRF协调器合约,然后建立一个最终种子,并将其发送到该VRF协调器的Chainlink预言机。最后的种子是用以下值的哈希值建立起来的。-用户提供的种子-满足请求的Chainlink预言机的公钥哈希值-请求时的用户nonce-提出请求的合约地址-当前区块号使用这些额外的值的原因是为了防止合约使用相同的种子不止一次地得到相同的结果。nonce有助于防止合约在同一区块内做多个请求,所以理论上,合约可以在同一区块内使用相同的种子为请求多个随机数,而且他们仍然会为每个请求得到唯一的可验证的随机数。`fulfillRandomness`函数接受随机数响应参数为一个无符号整数,以及请求的ID,然后将给定的随机数存储在合约中。当VRFCoordinator合约接收并验证一个随机数时,这个函数会被调用。关于这两个函数的更多信息可以在ChainlinkVRF文档中找到。

声音 | 中远海运董事长许立荣:如何将区块链等技术与航运业结合 是挑战也是机遇:据第一财经消息,7月11日,在“2019年中国航海日论坛”主论坛上,中国远洋海运集团有限公司董事长许立荣表示,“当前各种新技术更是层出不穷,大数据、云计算、区块链、无人驾驶、人工智能等。如何把这些新技术与古老的航运业相结合,创新商业模式,既是新的挑战,也是创新的难得机遇。”论坛上,新加坡海事与港口局局长柯丽芬介绍,以新加坡为营运基地的太平船务已成功试行了一套以区块链为基础的电子提单系统。转让销售证明书的行政程序时间大幅减少,从以往的7天,减少到只要1秒钟。[2019/7/11]

现在,我们在Solidity中拥有了一个完整且可行的随机数生成示例,现在可以部署和测试该合约了。测试随机数生成消费者合约以上完整的合约可以很方便地在Remix中打开、编译,并部署在Kovan网络上。部署好后,一定要给合约转入一些LINK。一旦合约至少有0.1个LINK的资金,我们就可以调用`getRandomNumber`函数,传入一个数字作为种子。这将把请求和种子一起发送给运行在Chainlinkoracle上的VRF协调器。

事务被处理后,需要等待几秒钟,让Chainlink预言机完成对随机数的请求,然后调用我们之前创建的'fulfillRandomness'函数,将随机数返回给我们的消费者合约。然后我们可以调用`randomResult`getter函数来查看Chainlinkoracle用给定种子生成的可验证随机数的结果。现在我们有了一个可验证的随机数,它可以在我们的消费者合约和任何其他应用中使用。

验证随机性

现在,我们有一个随机数返回到我们的合约,你可能会想知道,我们如何确定它是由执行请求的Chainlinkoracle的给定种子和公钥哈希生成的。当使用ChainlinkVRF时,答案是你不需要这样做。验证作为`VRFCoordinator`合约完成请求的一部分,会自动进行。如果验证失败,那么随机数就不会返回到消费合约,交易也会被还原。因此,使用ChainlinkVRF的区块链开发者可以放心,他们通过ChainlinkVRF获得的随机数是可验证的随机数。关于验证的底层技术细节,可以参考我们对ChainlinkVRF的技术演练。总结

ChainlinkVRF帮助Solidity开发者以安全、可靠和经过验证的方式在智能合约中快速、轻松地生成随机数。

标签:LINKINKHAINLINKGemlinkstarlink币价格Bee link chaintronlink波宝钱包怎么激活

USDC热门资讯
《年度区块链产业发展报告(2020)》重磅发布,透视产业应用现状与未来

2020年是区块链发展的关键之年,疫情加速了人类向数字世界迁移的步伐。这一年,区块链作为新技术基础设施被纳入“新基建”范围内,各地纷纷出台规划扶持区块链产业发展.

1900/1/1 0:00:00
头部交易所宣布下架XRP,这会是开始吗?

XRP产生的后续影响继续发酵,看起来正走向我们预期中最坏的那个结果。昨天在Coinbase表达了下架XRP的意向后,我们提及过,若是Coinbase做出这样的表态,那其他交易所也有很大的概率下架XRP,果不其然,今天Bitstamp就.

1900/1/1 0:00:00
Rebase算法稳定币,抢了机构的生意分给了所有用户,就如打土豪分田地

编者按:本文来自小吒闲谈,Odaily星球日报经授权转载。稳定币是币圈绕不开的话题,也是绕不开的东西。起初没有稳定币啥事情,因为那会法币出入很方便,交易直接用法币作为交易对.

1900/1/1 0:00:00
Kira世界整合全球资产

公链发展过程几乎可以说是我们认识区块链的一个自然演化的过程,从一开始的共识算法的研究,到可扩展性的探索,到生态的综合建设以及社区的治理,大家都在从不同的角度来不断的试错.

1900/1/1 0:00:00
比特币突破2万美元历史新高,与2017年相比有这些差别

北京时间12月16日21时30分,比特币价格飙升至历史新高,并突破20000美元,上涨势头强劲.

1900/1/1 0:00:00
天天等灰度上班,你真的了解灰度吗?

编者按:本文来自矩阵百科,Odaily星球日报经授权转载。 作为一个投资者,现在每天醒来的第一件事就是看灰度增持了什么币,增持了多少。灰度的动态已经成为很多人投资必看的指标。甚至有人说,如果你不知道买什么币,那就跟着灰度买.

1900/1/1 0:00:00