Solidity中无法原生地完成随机数生成。要在区块链上生成一个真正可验证的随机数,智能合约必须将种子发送到像预言机这样的链外资源,而预言机必须将随机数连同可验证的证明一起返回给智能合约,证明随机数是使用种子生成的。随着ChainlinkVRF现已在Ethereum主网上线,开发者可以在Solidity中以安全可靠、可验证的方式轻松生成随机数。在这篇技术文章中,我们将向您展示如何使用ChainlinkVRF在Solidity中生成随机数。在您的智能合约中生成安全随机数的例子可以在Chainlink文档中找到。这里有一个Remix上在Kovan测试网生成区块链随机数的例子,供现在想测试的人使用。只要记得按照请求和接收方法,用LINK转账到你的智能合约就可以了。ChainlinkVRF的高级概述
墨西哥官员会见Samson Mow讨论墨西哥如何采用Bitcoin:金色财经报道,Bitcoin Magazine在社交媒体上发文表示,墨西哥参议员兼财政部委员会主席会见Samson Mow讨论墨西哥如何采用Bitcoin。[2023/4/30 14:35:25]
ChainlinkVRF是一个为智能合约设计的公平的可验证的随机性来源。Solidity开发人员可以使用它作为防篡改的随机数生成器,为依赖不可预测结果的Ethereum应用构建安全可靠的智能合约。在Solidity中使用ChainlinkVRF生成随机数的第一步是确定一个种子。选择一个难以被影响或预测的种子极为重要。如果有人能够影响或预测种子,理论上他们可以尝试与执行随机性请求的预言机节点串通,产生一个对自己有利的结果。正因为如此,建议不要使用来自区块链状态的值,如区块高度或区块时间戳。然后,这个种子会以请求的方式发送到Chainlink预言机。然后,预言机会用给定的种子生成一个伪随机数,并将结果返回给智能合约,一同返回的还有一个加密证明,用来验证随机数是使用种子生成的。这种加密证明是通过公钥加密技术创建的,这是区块链技术中广泛使用的技术。重要的是,结果可以被验证,避免矿工或预言机等参与者为了自己的利益而影响随机数的结果。这是对ChainlinkVRF工作方式的高级概述。关于底层技术实现的更多细节可以在我们对ChainlinkVRF的介绍中找到。然而,作为开发者,除了获取种子,然后向Chainlink预言机创建一个请求之外,你不需要担心任何事情。创建消费者合约如何在Solidity智能合约中获得一个随机数,我们应该首先从ChainlinkVRFConsumerBase合约中继承。消费者合约还应该包含存储随机数结果的变量,用于生成随机性的公钥哈希,以及为完成请求而付给预言机的费用。
Life预言机协议:正在探索如何把真实数据存储在Filecoin网络:北京时间2021年5月18日15时,Life预言机协议官方发布博客表示正在探索如何把真实数据存储在Filecoin网络。Life去中心化数据预言机协议启动于2017年,旨在实现区块链与现实世界的数据可信交互。Life是一个集成了智能合约、加密算法、通证经济以及各种API的综合性去中心化预言机网络。生态参与者可依靠智能硬件采集设备进行海量数据收集,后端接入Life完成数据的加密存储、确权和自由流转。目前Life与可信硬件厂商的合作开发已经进展到了最后的阶段,相关可信硬件(数据采集设备)已经研发完成,不久将会上市。Life技术团队目前正基于Filecoin网络完善相关的API,以实现可信硬件采集的数据可直接上传至Filecoin网络。[2021/5/19 22:20:00]
直播 | 方鱼 > 老牌交易所满币如何在合约市场异军突起:金色财经 · 直播主办的《 币圈 “后浪” 仙女直播周》第5期本期3:00准时开始,本期“后浪”仙女 满币网 CMO 将在直播间聊聊“老牌交易所满币如何在合约市场异军突起”,感兴趣的朋友扫码移步收听![2020/6/18]
接下来,在构造函数中,我们应该初始化ChainlinkVRF协调器。调用VRFConsumerBase函数,传入VRF协调器的地址和给定环境的Chainlinktoken的地址作为参数。还需要设置keyHash变量,这是生成随机性的公钥。这些的环境特定值可以在ChainlinkVRF文档的合约地址部分获得。最后,我们需要设置LINKtoken的支付金额。对于Kovan测试环境,它是0.1个LINK。
大咖零距离 | 行情巨震 如何合理配置币圈资产:3月30日16:00,由金色盘面主办、BTSE交易所独家赞助的《大咖零距离》正式开播。届时BTSE联合创始人/CPO BrianWong,将在《大咖零距离》直播间分享《行情巨震,如何合理配置币圈资产》,敬请关注,欲进群观看直播扫描海报二维码报名即可![2020/3/30]
接下来,我们重写合同中的两个函数`getRandomNumber`和`fulfillRandomness`。`getRandomNumber`函数应该把种子作为输入参数,并且调用VRFConsumerBase中的`requestRandomness`函数,传递keyHash,费用金额和给定的种子作为参数。
动态 | Cryptopia清算跟进:总资产为170万美元 清算人需向法院咨询如何支付欠款:据rnz消息,Cryptopia清算公司Grant Thornton需要就如何现款支付客户欠款向法庭寻求法律咨询,因为世界上还未有任何法律先例。来自Grant Thornton的清算人David Ruscoe和David Ruscoe发布报告称,Cryptopia目前欠款超过400万美元,而总资产为170万美元。本周,法院下达命令,允许他们使用该公司持有的比特币为清算提供资金。 据此前消息,Grant Thornton发布清算报告显示,Cryptopia欠69名无担保债权人债务超过210万美元,有担保债权人的债务超过140万美元。此外,该公司欠员工未付工资、假期工资以及无担保债务近60万美元,预计无担保债权人的数量将会增加。在今年1月份遭黑客入侵损失1600万美元后,Cryptopia目前已申请美国破产保护。[2019/6/1]
执行时,这个函数将请求发送到给定的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开发者以安全、可靠和经过验证的方式在智能合约中快速、轻松地生成随机数。
标签:LINKINKAINCHAMedical data linkSPLINKCOV ChainBerylTrioChain
随着Telegram活跃用户数接近5亿,很多人都在问一个问题--谁来支付支持这种增长所需的开支?毕竟,更多的用户意味着更多的流量和服务器的开支.
一、基本情况 1.1项目简介 Compound是一个基于算法的抵押借贷协议,给用户提供了活期的浮动利率存款和借贷服务.
编者按:本文来自链闻ChainNews,星球日报经授权发布。整理:SoonaAmhaz,TokenDaily联合创始人,VoltCapital普通合伙人翻译:卢江飞又到了一年结束的时候,和往年一.
墨客/吉米AMPL,一个月持有涨幅88倍收益!相信经历过2020年7-9月的DeFi牛市的人都不会对AMPL感到陌生.
头条 过去30天灰度共增持逾36.5万枚ETH和5.4万枚BTC加密分析公司Bybt.com发布数据报告称,过去30天内,灰度投资公司一共购买超过36.5万枚以太坊.
存储板块:MAID继续上涨10%;FilecoinGas费创新高,达到4.7nanoFIL;FIL7日净流出4000万美元.