木星链 木星链
Ctrl+D收藏木星链

LOCK:科普 | 智能合约安全审计入门篇 —— 溢出漏洞

作者:

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

By:小白@慢雾安全团队

背景概述

上周写了智能合约安全审计入门篇——重入漏洞,这次我们接着来说一个同样很经典的漏洞——?溢出漏洞。

前置知识

首先我们还是先来看看溢出是什么:

算术溢出或简称为溢出分为两种:上溢和下溢。所谓上溢是指在运行单项数值计算时,当计算产生出来的结果非常大,大于寄存器或存储器所能存储或表示的能力限制就会产生上溢,例如在solidity中,uint8所能表示的范围是0-255这256个数,当使用uint8类型在实际运算中计算255+1是会出现上溢的,这样计算出来的结果为0也就是uint8类型可表示的最小值。同样的,下溢就是当计算产生出来的结果非常小,小于寄存器或存储器所能存储或表示的能力限制就会产生下溢。例如在Solidity中,当使用uint8类型计算0-1时就会产生下溢,这样计算出来的值为255也就是uint8类型可表示的最大值。

如果一个合约有溢出漏洞的话会导致计算的实际结果和预期的结果产生非常大的差异,这样轻则会影响合约的正常逻辑,重则会导致合约中的资金丢失。但是溢出漏洞是存在版本限制的,在Solidity<0

国务院:推进科普与区块链技术深度融合:为贯彻落实党中央、国务院关于科普和科学素质建设的重要部署,依据《中华人民共和国科学技术进步法》、《中华人民共和国科学技术普及法》制定《全民科学素质行动规划纲要(2021-2035年)》,其中要求实施智慧科普建设工程。推进科普与区块链等技术深度融合,强化需求感知、用户分层、情景应用理念,推动传播方式、组织动员、运营服务等创新升级,加强“科普中国”建设,强化科普信息落地应用,与智慧教育、智慧城市、智慧社区等深度融合。(新华社)[2021/7/10 0:40:52]

functionincreaseLockTime(uint_secondsToIncrease)public{lockTime+=_secondsToIncrease;}

functionwithdraw()public{require(balances>0,"Insufficientfunds");require(block

}

漏洞分析

我们可以看到,TimeLock合约充当了时间保险库。用户可以将代币通过deposit函数存入该合约并锁定,且至少一周内不能提现。当然用户也可以通过increaseLockTime函数来增加存储时间,用户在设定的存储期限到期前是无法提取TimeLock合约中锁定的代币的。首先我们发现这个合约中的increaseLockTime函数和deposit函数具有运算功能,并且合约支持的版本是:0

fallback()externalpayable{}

functionattack()publicpayable{timeLock

}

这里我们将使用Attack攻击合约先存入以太后利用合约的溢出漏洞在存储未到期的情况下提取我们在刚刚TimeLock合约中存入并锁定的以太:

1.首先部署TimeLock合约;

2.再部署Attack合约并在构造函数中传入TimeLock合约的地址;

3.调用Attack.attack函数,Attack.attack又调用TimeLock.deposit函数向TimeLock合约中存入一个以太,之后Attack.attack又调用TimeLock.increaseLockTime函数并传入uint类型可表示的最大值加1再减去当前TimeLock合约中记录的锁定时间。此时TimeLock.increaseLockTime函数中的lockTime的计算结果为2^256这个值,在uint256类型中2^256这个数存在上溢所以计算结果为2^256=0此时我们刚刚存入TimeLock合约中的一个以太的锁定时间就变为0;

4.这时Attack.attack再调用TimeLock.withdraw函数将成功通过block.timestamp>lockTime这项检查让我们能够在存储时间未到期的情况下成功提前取出我们刚刚在TimeLock合约中存入并锁定的那个以太。

下面是攻击流程图:

修复建议

到这里相信大家对溢出漏洞都有自己的理解了,那么下面我们就以开发者和审计者的角度来分析如何预防溢出漏洞和如何快速找出溢出漏洞:

作为开发者

1.使用SafeMath来防止溢出;

2.使用Solidity0.8及以上版本来开发合约并慎用unchecked因为在unchecked修饰的代码块里面是不会对参数进行溢出检查的;

3.需要慎用变量类型强制转换,例如将uint256类型的参数强转为uint8类型由于两种类型的取值范围不同也可能会导致溢出。

作为审计者

1.首先查看合约版本是否在Solidity0.8版本以下或者是否存在unchecked修饰的代码块,如果存在则优先检查参数的溢出可能并确定影响范围;

2.如果合约版本在Solidity0.8版本以下则需要查看合约是否引用了SafeMath;

3.如果使用了SafeMath我们需要注意合约中有没有强制类型转换,如果有的话则可能会存在溢出的风险;

4.如果没有使用SafeMath且合约中存在算术运算的我们就可以认为这个合约是可能存在溢出风险的,在实际审计中还要结合实际代码来看。

标签:LOCKIMELOCTIMANY BlocknetDIME币blockchain是什么意思中文翻译Pepe Optimus

以太坊最新价格热门资讯
BDC:汇丰集团和IBM成功创建多账本CBDC演示

周四,汇丰集团和IBM宣布在云环境中成功测试了两种央行数字货币(CBDC)之间的高级代币和数字钱包结算。试验包括CBDC、eBond和外汇之间的交易.

1900/1/1 0:00:00
NFT:NFT游戏DOGAMí完成600万美元Pre-Seed轮融资,育碧、Animoca Brands参投

据Cointelegraph12月23日消息,基于Tezos的Play-to-EarnNFT游戏项目DOGAMí完成600万美元Pre-Seed轮融资.

1900/1/1 0:00:00
FTX:知名众筹平台Kickstarter计划基于Celo建立去中心化众筹协议

据TheBlock消息,12月9日,知名众筹平台Kickstarterr宣布计划基于Celo区块链建立去中心化众筹协议,并将在2022年将其网站过渡到新协议上.

1900/1/1 0:00:00
DOR:Dorsey离开Twitter后希望专注于加密货币和慈善事业,推特新任CEO支持“去中心化”的思想

据sputniknews11月30日报道,Twitter宣布其首席执行官JackDorsey辞职,担任首席技术官的ParagAgrawal接替他的职位.

1900/1/1 0:00:00
元宇宙:“元”经济的黎明

“你来到了这里,其他人围在你身边,但他们不理解你,你也不理解他们,然而人们还是要说很多毫无意义的废话。为了活下去,你只能每天从早到晚不停地做这种愚蠢又没有意义的活计.

1900/1/1 0:00:00
MARBLE:韩国游戏开发商Krafton进军元宇宙,已向Naver Z投资50亿韩元

据Forkast12月6日消息,韩国游戏开发商Krafton已在今年7月向NaverZ投资50亿韩元,旨在进军元宇宙市场.

1900/1/1 0:00:00