逸学区块链【solidity】真随机数

参考Get a Random Number | Chainlink Documentation

但是很贵,价格

  • **Gas Price:**当前gas价格,根据网络状况而波动。
  • **Callback gas :**返回您所请求的随机值时,回调请求消耗的gas 量。
  • **验证gas :**量gas 用于验证链上的随机性。

我们可以定义两个内容限制总价格,也就是限制当前gas价格和回调请求消耗的gas 量

keyHash:Gas通道( 最大gas价格您愿意为请求支付的价格(以 wei 为单位)

callbackGasLimit: 回调上限 示例中100000是愿意为请求花费的上限,限制价格

有计算器VRF Billing | Chainlink Documentation

javascript 复制代码
// SPDX-License-Identifier: MIT
// 一个依靠订阅获得资金的消费者合同的例子
pragma solidity ^0.8.7;

import "@chainlink/contracts/src/v0.8/interfaces/VRFCoordinatorV2Interface.sol";
import "@chainlink/contracts/src/v0.8/VRFConsumerBaseV2.sol";

contract VRFv2Consumer is VRFConsumerBaseV2 {
  VRFCoordinatorV2Interface COORDINATOR;

  // 您的订阅ID.
  //https://vrf.chain.link/
  uint64 s_subscriptionId;

  // Rinkeby协调员。对于其他网络,
  // 参照 <https://docs.chain.link/docs/vrf-contracts/#configurations>
  address vrfCoordinator = 0xc587d9053cd1118f25F645F9E08BB98c9712A4EE;

  // 要使用的gas通道,每个网络不一样.
  // 参照 <https://docs.chain.link/docs/vrf-contracts/#configurations>
  //交换地址https://pegswap.chain.link/
  bytes32 keyHash = 0x114f3da0a805b6a67d6e9cd2ec746f7028f1b7376365af575cfea3550dd1aa04;

    //取决于要发送到的请求值的数量
    //对于fulfillRandomWords()函数。存储一个数值需要消耗20000wei,
    //因此,对于这个示例合同,100000是个安全的默认值
  uint32 callbackGasLimit = 30000;

  // 请求的信息数量,默认是3,你可以设置更高
  uint16 requestConfirmations = 3;

  //此用例中,默认-次获得2个随机数
  uint32 numWords =  1;

  uint256[] public s_randomWords;
  uint256 public s_requestId;
  address s_owner;

  constructor(uint64 subscriptionId) VRFConsumerBaseV2(vrfCoordinator) {
    COORDINATOR = VRFCoordinatorV2Interface(vrfCoordinator);
    s_owner = msg.sender;
    s_subscriptionId = subscriptionId;
  }

  // /假设Link充足的情况下,执行此函数
  function requestRandomWords() external onlyOwner {
    // 如果没设置订阅的相关关系,就会报错
    s_requestId = COORDINATOR.requestRandomWords(
      keyHash,
      s_subscriptionId,
      requestConfirmations,
      callbackGasLimit,
      numWords
    );
  }
  
  function fulfillRandomWords(
    uint256, 
    uint256[] memory randomWords
  ) internal override {
    s_randomWords = randomWords;
  }

  modifier onlyOwner() {
    require(msg.sender == s_owner);
    _;
  }
}

需要配置网路和订阅

Supported Networks - Subscription Method | Chainlink Documentation

订阅

VRF | Subscription Management

部署的时候对应上

Remix - Ethereum IDE

相关推荐
cmes_love4 小时前
股票逐笔level2历史行情下载十档订单薄五档tick分钟下载分享
数据库·区块链
HavenlonLabs8 小时前
区块链解决信任分布,AI 需要解决能力控制
人工智能·安全·区块链
选择不变8 小时前
死磕牛市主升浪战法(趋势确认 + 洗盘低吸 + 主升浪持有 + 止盈止损)阅读量 1000 万 +,点赞 11 万的文章
区块链
Bczheng113 小时前
二十九.签名与脚本(4)--脚本验证例子
区块链
软件工程小施同学14 小时前
CCF A区块链论文分享-NDSS 2026(2)-CtPhishCapture:揭露针对加密货币钱包的基于凭证窃取的网络钓鱼诈骗(附pdf)
网络·pdf·区块链
Zhan86112418 小时前
数据接口的序列号机制与丢包检测:西班牙行情数据IBEX指数实时行情接入笔记
大数据·数据结构·笔记·区块链
CTA量化套保1 天前
期货量化程序 time.sleep 卡死:天勤单线程与 deadline 替代
python·区块链
东方隐侠安全团队-千里1 天前
币安Skills Hub:散户的“机构级超能力“来了
安全·ai·区块链·skills
终端域名1 天前
AI与区块链融合:加密货币的下一前沿——技术架构、企业价值与未来趋势
人工智能·架构·区块链
Richown1 天前
区块链治理:DAO与去中心化治理机制
区块链·react