火星链 火星链
Ctrl+D收藏火星链
首页 > MATIC > 正文

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

作者:

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

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

中央纪委国家监委网站发文《元宇宙如何改写人类社会生活》:12月23日消息,中央纪委国家监委网站于今日发文《元宇宙如何改写人类社会生活》,文中解释了什么是元宇宙,元宇宙为什么能出圈,并且提到要“理性看待元宇宙带来的新一轮技术革命和对社会的影响,不低估5-10年的机会,也不高估1-2年的演进变化”。[2021/12/23 7:59:46]

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

大咖零距离 | 宝二爷,李笑来的成功我们能复制吗?该如何抓住减半行情?:3月3日18:00,金色盘面邀请币圈KOL老俞说币做客金色财经《大咖零距离》直播间,将分享《宝二爷,李笑来的成功我们能复制吗?该如何抓住减半行情?》,敬请关注,欲进群观看直播扫描海报二维码报名即可![2020/3/3]

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

动态 | Kyle Samani发推质疑Block.one如何在两年时间花掉 8 亿美元:著名区块链投资机构 Multicoin 创始合伙人 Kyle Samani 发推质疑 EOS 背后的开发公司 Block.one 如何在两年时间中烧掉 8 亿美元。Kyle Samani 发表推文称,如果 Block.one 通过 ICO 融资了 40 亿美元,现在的资产负债表上有 32 亿美元的资产,那么这家有 200 名员工的公司如何在两年时间里花掉了 8 亿美元现金?Kyle Samani 还称,Block.one 进行了 1.8 亿美元风险投资,但这不是支出,即便把这些投资的账面资产都减记为 0 ,时间也不够用。而 Staked.us 的联合创始人 Jonathan Marcus 则表示,Block.one 花费的那 8 亿美元中,最少有 5.3 亿美元用于股权回购,因为 Block.one 过去两年共进行了两次股权回购,一次花费了 3 亿美元,最近又回购了 2.3 亿美元的股权。[2019/6/3]

现场 | 降维安全CTO:交易所应该如何保护数字资产:12月16日,由ChainUP主办,节点资本等联合主办的“Future BlockChain”全球行活动在韩国举办。降维安全CTO在会议中表示,交易所主要面临Hacker、恶意量化团队、恶意用户、恶意项目方这些外部攻击。具体到黑客攻击有以下四点:DoS勒索、Web渗透/APT社会工程学攻击以及利用区块链项目自身的漏洞进行攻击。据降维安全统计,交易所应用(不涉及期货合约)风险,共有5大类,14个子类,68个风险点。他表示:专业的事情应该交给专业的人做,选择专业的交易所系统和专业的安全服务商,非常重要。[2018/12/16]

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

中国信通院云计算与大数据研究所所长何宝宏:区块链中如何使用共识机制是大问题:中国信通院云计算与大数据研究所所长何宝宏:区块链是唯一崛起于草根的颠覆性技术,越来越多的行业应用正在采用分布式账本技术;在区块链中如何使用共识机制是大问题,当信任缺失时,共识机制十分消耗算力;区块链技术人才需求朝复合型方向发展。[2017/12/22]

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

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

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

验证随机性

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

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

标签:INKLINKChainCHAlink币值得长期持有吗chainlink币qinbchainblueseachain

MATIC热门资讯
CHA:比特币、稳定币和DeFi:2020年表现最好的加密资产

编者按:本文来自Cointelegraph中文,作者:JOSEPHYOUNG,Odaily星球日报经授权转载.

1900/1/1 0:00:00
TER:过度的热点:一文看懂算法稳定币的本质

编者按:本文来自WebX实验室Daily,Odaily星球日报经授权转载。加密货币的DeFi市场又掀起一波新的高潮,这次焦点落在了稳定币身上,而这次的稳定币显然是更具有想象力的,凭借计算机代码控.

1900/1/1 0:00:00
GBT:站上2万美金,比特币为什么一年能涨3倍?

编者按:本文来自区块律动BlockBeats,Odaily星球日报经授权转载。2020年的最后一个月,一定会在加密货币的历史复盘中被一遍又一遍被提及,全球加密货币总龙头比特币先是刷新了自己的历史.

1900/1/1 0:00:00
KEX:OKEx“碰瓷”苹果,重新定义交易到底靠不靠谱?

13年前,苹果公司第一代iPhone手机横空出世,追求速度、优雅与极简美学。彼时的手机市场,诺基亚常年领跑,摩托罗拉、黑莓、三星虎视眈眈,手机耐摔、信号强几乎是行业标配.

1900/1/1 0:00:00
MIC:为什么美上市公司MicroStrategy会不停「买买买」比特币?

碳链价值原创团队编译8月11日,MicroStrategy宣布已在比特币上投资了2.5亿美元,从此吹起了机构投资者进军比特币市场的号角;9月8日.

1900/1/1 0:00:00
COI:IPFS周报 | FIL 7日净流出增长77%,FIL周内下跌6%;Filecoin主网昨日出现短时宕机(12.14-12.20)

MAID连续三周暴涨,Holo跻身1亿美元市值「俱乐部」;Filecoin网络12月20日短时宕机.

1900/1/1 0:00:00