区块见闻 区块见闻
Ctrl+D收藏区块见闻
首页 > 以太坊 > 正文

智能合约安全审计入门篇 : 重入漏洞

作者:

时间:

背景概述

看了一个关于学习 solidity 的站(https://solidity-by-example.org),里面讲了关于 solidity 智能合约的很多漏洞,考虑到现在针对智能合约的攻击事件频频发生,不法分子盗取的加密资产越来越多,我就想写一些与智能合约安全审计相关的文章给想了解智能合约安全审计的入门者阅读,让一些对智能合约安全审计感兴趣的初学者可以学到如何识别一些常见的漏洞和如何利用这些漏洞去做什么事情。这次我们就一起先看一个很经典的漏洞 —— 重入漏洞。

前置知识

重入漏洞相信大家都有所耳闻了,那么什么是重入漏洞呢?

以太坊智能合约的特点之一是合约之间可以进行相互间的外部调用。同时,以太坊的转账不仅仅局限于外部账户,合约账户同样可以拥有以太并进行转账等操作,且合约在接收以太的时候会触发 fallback 函数执行相应的逻辑,这是一种隐藏的外部调用。

我们先给重入漏洞下个定义:可以认为合约中所有的外部调用都是不安全的,都有可能存在重入漏洞。例如:如果外部调用的目标是一个攻击者可以控制的恶意的合约,那么当被攻击的合约在调用恶意合约的时候攻击者可以执行恶意的逻辑然后再重新进入到被攻击合约的内部,通过这样的方式来发起一笔非预期的外部调用,从而影响被攻击合约正常的执行逻辑。

澳大利亚证交所加密市场关联ETF首日交易额破纪录:11月4日消息,澳大利亚证交所(ASX)首只加密市场关联ETF BetaShares Crypto Innovators ETF(ASX:CRYP)于周四上午10点30分开始交易,15分钟后,交易额已达800万美元,到下午1点达到2800万美元。这创下了在ASX上市的ETF首日交易额的记录,此前的记录为Hyperion今年3月创下的800万美元。该ETF的推出是ASX首次涉足与加密市场相关的投资产品。它不直接投资于加密货币或数字资产,而是通过投资参与市场的全球公司(如比特币矿企和加密交易平台)提供风险敞口。(澳洲经济评论)[2021/11/4 21:24:52]

漏洞示例

好了,看完上面的前置知识我相信大家对重入漏洞都有了一个大致的了解,那么在真实的环境中开发者写出什么样的代码会出现重入漏洞呢,下面我们来看一个比较典型的有重入漏洞的代码:

漏洞分析

看到这里大家可能会有疑惑了,上面的代码就是个普通的充提币的合约,凭什么说他有重入攻击呢?我们来看这个合约的 withdraw 函数,这个函数中的转账操作有一个外部调用(msg.sender.call{value: bal}),所以我们就可以认为这个合约是可能有重入漏洞的,但是具体能否产生危害还需要更深入的分析:

中币(ZB)FIL6Z今日最高涨幅8.47%:据中币(ZB)官网数据显示,FIL6Z 24小时内最高涨幅达8.47%,当前涨幅8.47%,最高价格216.8QC(31.8USDT),当前报价206.58QC(约30.37USDT)。行情波动较大,请注意控制风险。

据悉,昨日中币发布公告,公布其Filecoin期货FIL6Z和QFIL的兑付方式,其中FIL6Z完整兑付周期为180天,QFIL为15到30天之内。[2020/10/12]

1. 所有的外部调用都是不安全的且合约在接收以太的时候会触发 fallback 函数执行相应的逻辑,这是一种隐藏的外部调用,这种隐藏的外部调用是否会造成危害呢?

2. 我们可以看到在 withdraw 函数中是先执行外部调用进行转账后才将账户余额清零的,那我们可不可以在转账外部调用的时候构造一个恶意的逻辑合约在合约执行 balance[msg.sender]=0 之前一直循环调用 withdraw 函数一直提币从而将合约账户清空呢?

下面我们看看攻击者编写的攻击合约中的攻击手法是否与我们的漏洞分析相同:

攻击合约

我们看到 EtherStore 合约是一个充提合约,我们可以在其中充提以太。下面我们将利用攻击合约将 EtherStore 合约中用户的余额清零的:

这里我们将引用三个角色,分别为:

用户:Alice,Bob

攻击者:Eve

1. 部署 EtherStore 合约;

2. 用户 1(Alice)和用户 2(Bob)都分别将 1 个以太币充值到 EtherStore 合约中;

3. 攻击者 Eve 部署 Attack 合约时传入 EtherStore 合约的地址;

4. 攻击者 Eve 调用 Attack.attack 函数,Attack.attack 又调用 EtherStore.deposit 函数,充值 1 个以太币到 EtherStore 合约中,此时 EtherStore 合约中共有 3 个以太,分别为 Alice、Bob 的 2 个以太和攻击者 Eve 刚刚充值进去的 1 个以太。然后 Attack.attack 又调用 EtherStore.withdraw 函数将自己刚刚充值的以太取出,此时 EtherStore 合约中就只剩下 Alice、Bob 的 2 个以太了;

5. 当 Attack.attack 调用 EtherStore.withdraw 提取了先前 Eve 充值的 1 个以太时会触发 Attack.fallback 函数。这时只要 EtherStore 合约中的以太大于或等于 1 Attack.fallback 就会一直调用 EtherStore.withdraw 函数将 EtherStore 合约中的以太提取到 Attack 合约中,直到 EtherStore 合约中的以太小于 1 。这样攻击者 Eve 会得到 EtherStore 合约中剩下的 2 个以太币(Alice、Bob 充值的两枚以太币)。

下面是攻击者的函数调用流程图:

修复建议

看了上面的攻击手法相信大家对重入漏洞都会有一个自己的认知,但是只会攻击可不行,我们的目的是为了防御,那么作为开发人员如何避免写出漏洞代码还有作为审计人员如何快速发现问题代码呢,下面我们就以这两个身份来分析如何防御重入漏洞和如何在代码中快速找出重入漏洞:

(1)作为开发人员

站在开发者的角度我们需要做的是写好代码,避免重入漏洞的产生。

1. 写代码时需要遵循先判断,后写入变量在进行外部调用的编码规范(Checks-Effects-Interactions);

2. 加入防重入锁。

下面是一个防重入锁的代码示例:

(2)作为审计人员

作为审计人员我们需要关注的是重入漏洞的特征:所有涉及到外部合约调用的代码位置都是不安全的。这样在审计过程中需要重点关注外部调用,然后推演外部调用可能产生的危害,这样就能判断这个地方是否会因为重入点而产生危害。

标签:TORETHERSTACKTORII币togetherbnb手游下载最新版TRST价格DAOslack

以太坊热门资讯
盲人摸“DAO”

“Everything is Meme”,这句话在MemeC.oin爆发的那段时间里特别流行。从前作为一名自视过高的“SmartMoney”,我并不是很理解这句话,喜欢研究的特性使得在选择项目的时候过分关注细节和解决方案。导致养成了看这也不行,看那也不行的坏毛病。

金色观察|Multicoin创始人:为什么下次熊市不会像上次一样

Multicoin联合创始人、管理合伙人Kyle Samani于12月13日发文认为下一次熊市不会像上次那样,他表示“事实上,我们可能根本不会有熊市,或者我们可能有半个熊市”,并解释如下: 广义上讲,加密货币领域有两类人:货币加密主义者和技术加密主义者。

几位 Crypto CEO 国会山听证会部分实录总结

哈喽晚上好, 今天的是美国众议员关于数字资产的一次听证会,如果使用创新的产品和服务是如何重塑金融系统,如何帮助保护用户、投资者等。 总体听下来,还是很正面的。 主席 Ms.Waters 大概介绍了背景:数字资产在美国的使用越来越多,所以请了一些公司的负责人聊一聊他们的产品、服务和技术本身。

全国首笔数字人民币缴纳执行案款落地雄安法院

中国雄安官网12月14日电 12月9日,全国首笔数字人民币缴纳执行案款在雄安新区雄县人民法院成功落地。这是继雄安新区两级法院在全省率先实现执行案款“一案一码”线上支付方式后的又一创新突破,标志着雄安新区法院系统在深化数字人民币应用方面又跨出了重要一步。

ZK-rollup成为Layer 2关注焦点 现状怎样了?

原标题:随着对扩展以太坊的探索不断发展,ZK-rollup成为关注焦点 以太坊网络的可扩展性多年来一直是加密货币生态系统中的一个争论点,主要原因是高昂的费用和在需求高峰期间的网络拥堵。 作为解决以太坊可扩展性问题的最终解决方案,最新出现的解决方案是零知识rollup(ZK rollup),这是一种在链下运行计算并通过有效性证明提交到链上的扩展形式。

链游公会打金热背后:多由矿工转型 存在多重风险

今年8月,当Yield Guild Games 紧随头部链游 Axie Infinity 迎来市场热度时,大多数人都没有料到「链游公会」会成为一个专门的赛道,甚至可以说,爆火的赛道。 在最近一月链捕手的每周融资统计中,链游公会获得融资的频率仅次于链游项目本身,a16z等诸多头部风投机构都在布局该赛道。