月亮链 月亮链
Ctrl+D收藏月亮链

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

作者:

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

背景概述

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

前置知识

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

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

Babylon上线测试网V0.7.1,启用CosmWasm智能合约支持:6月20日消息,旨在将比特币安全性带至Cosmos生态的项目Babylon宣布上线Babylon测试网V0.7.1,启用CosmWasm智能合约支持以及IBC客户端双向数据共享等。[2023/6/20 21:49:35]

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

漏洞示例

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

数据:智能合约中的LINK供应量比例刷新两年高点:Glassnode数据显示,智能合约中的LINK供应量比例已达到51.282%,刷新两年高点。[2020/7/5]

漏洞分析

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

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

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

声音 | 开发人员:实施EIP-1884属于故意“打破”智能合约 但会在硬分叉中予以修复:Parity Tech的Rust开发人员Wei Tang发推称,继DAO和EIP-999之后,伊斯坦布尔升级将成为以太坊的第三个决定性时刻。伊斯坦布尔升级中一个变更——EIP-1884将是一个向后不兼容的变更,我们故意打破正常的(非攻击)智能合约,并承诺使用未来的硬分叉来修复它们,这对于以太坊网络来说尚属首次。随后Tang在回复网友问题时补充道,不过,这并不是我们第一次引入向后不兼容的变更。应该已经有几十个了。第一个可能是EIP-150,当时我们增加了一些gas成本来修复网络攻击。[2019/9/7]

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

攻击合约

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

富士通开发出检测智能合约风险技术:富士通研究所以及中国富士通开发中心,已经实现了能够检测智能合约上的风险,并在源代码上标示出来。本次技术的细目发表在了BSC(Blockchains and Smart Contracts Workshop)2018大会上,本次会议2月26日到28日在法国巴黎举办。[2018/3/7]

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

用户: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)作为审计人员

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

标签:STORSTETHACKSTONED价格Uberstate RIT2.0etheral代表什么意义EOSJacks

比特币最新价格热门资讯
NFT:披头士乐队罕见的音频采访将作为NFT发布_以太坊交易所清算

几十年来世界上最受欢迎的乐队之一现在正在准备发布NFT。披头士乐队的约翰·列侬、保罗·麦卡特尼、乔治·哈里森和林戈·斯塔尔的独家专访将作为NFT进行拍卖.

1900/1/1 0:00:00
元宇宙:万向区块链肖风:元宇宙与电信运营商_数字货币

 前言12月7日,万向区块链董事长兼总经理肖风博士受邀在GSMA-5G创新与投资论坛发表演讲.

1900/1/1 0:00:00
WEB:Web3.0 去中心化工作即将到来_WEB3

互联网改变了工作。起初,工作受到地域限制,你在农场、办公室或工厂工作,通过互联网,您可以在世界任何地方工作。不久之后,我们看到工作从一对多(雇员到雇主)转变为多对多(零工经济).

1900/1/1 0:00:00
DEF:Bitwise 发布 DeFi 展望:预测未来十年 DeFi 会像亚马逊一样颠覆市场_definer币币币情

资产管理公司Bitwise发布了一份题为《去中心化金融(DeFi):专业投资者入门》的报告。报告指出,尽管数字技术重塑了许多行业,但并未重塑金融.

1900/1/1 0:00:00
ALA:链游圈的Steam?爆火的Gala Games是什么?_GAME

11月30日,GALA/USDT的24小时成交额为2.4亿美元,在欧易成交榜中排第5。据行情数据显示,GALA代币价格在近几个月价格稳步上涨,并在11月中旬开始蓄力上涨,最高触达0.8427美元.

1900/1/1 0:00:00
元宇宙:?清华大学教授史元春:“元宇宙”还只是科幻_Credmark

近日,清华大学计算机教授史元春作客阿里研究院,参加“科技与人——元宇宙跨界对话”,与技术专家和科幻作家一起讨论当下最热门的“元宇宙”.

1900/1/1 0:00:00