如何在 Solidity 中生成随机数?

时间:2022-12-09 12:04:53

Solidity 中的数字生成是在Solidity 智能合约中创建随机数的过程。这可用于各种目的,例如为对象生成唯一 ID、在游戏中创建随机结果或选择随机参与者进行抽奖。

数字生成是 Solidity 的一个重要特性,因为它允许智能合约具有更大的灵活性和功能。

要在 Solidity 中生成随机数,请按照以下步骤操作:

 1. 创建一个​​RandomNumber​​合约

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
contract RandomNumber {

}

2. 创建一个名为的函数​​generateRandomNumber​​​,它不接受任何参数并返回一个​​uint​​值。

function generateRandomNumber() public view returns (uint) {
// code to generate random number goes here
}

3. 在​​generateRandomNumber​​​函数内部,创建一个名为的变量​​timestamp​​​,用于存储当前块的时间戳。这可以使用​​block.timestamp​​变量获得。

function generateRandomNumber() public view returns (uint) {
uint timestamp = block.timestamp;
}

4. 使用​​keccak256​​​库对​​timestamp​​​变量进行散列并将生成的散列存储在​​bytes32​​​名为 的变量中​​hash​​。

function generateRandomNumber() public view returns (uint) {
uint timestamp = block.timestamp;
bytes32 hash = keccak256(abi.encodePacked(timestamp));
}
  1. 使用​​bytesToUint​​​函数将 ​​hash​​​ 转为 ​​uint​​ 类型
function generateRandomNumber() public view returns (uint) {
uint timestamp = block.timestamp;
bytes32 hash = keccak256(abi.encodePacked(timestamp));
return bytesToUint(hash);
}

6. 合约中​​bytesToUint​​​函数的作用是 byte32 转 uint256:

function bytesToUint(bytes32 b) public pure returns (uint256) {
uint256 number;
for (uint256 i = 0; i < b.length; i++) {
number = number + uint8(b[i]) * (2**(8 * (b.length - (i + 1))));
}
return number;
}

最终代码

如何在 Solidity 中生成随机数?

运行效果

如何在 Solidity 中生成随机数?

注意:该方法的随机性取决于区块时间戳,并不一定是真正随机的。建议使用更安全的方法生成随机数,例如使用随机数预言机服务。