1、前言
北京时间3月5日,知道创宇区块链安全实验室?监测到?BaconProtocol?遭受黑客攻击损失约958,166美元,本次攻击利用重入漏洞,并凭借闪电贷扩大收益额。目前攻击者地址还没有被加入USDC的黑名单中。
2、分析
攻击事件如下图所示,该次攻击事件的问题点在于lend()函数,攻击者利用该函数进行重入攻击。
2.1基础信息
攻击合约:0x580cac65c2620d194371ef29eb887a7d8dcc91bf
攻击者地址:0x7c42f2a7d9ad01294ecef9be1e38272c84607593
MXC抹茶BHD杠杆擂台赛结束,第一名获得1004.10 枚BHD:官方消息,MXC抹茶BHD杠杆擂台赛现已结束,在“交易排行榜奖”中,第一名获得1004.10 枚BHD奖励,合约等值2BTC(具体以发放时BHD和BTC价格为准),其他中奖者按交易额分别获得20.08-304.23BHD奖励。
本次活动代币奖励,由BHD官方提供。
奖励公告请查看官方链接。[2020/5/3]
攻击tx:0x7d2296bcb936aa5e2397ddf8ccba59f54a178c3901666b49291d880369dbcf31
漏洞合约:0x781ad73f140815763d9A4D4752DAf9203361D07D
BHEX完成BHT第九次销毁 累计销毁已超5亿枚:据BHEX交易所公告,BHEX于新加坡时间4月8日19:00完成平台币BHT 2020年第一季度回购销毁。此次销毁包括回购销毁和解锁后销毁,共计销毁74,712,338枚BHT。截至现在,BHT累计销毁536,318,608枚。BHEX交易所是技术驱动的加密资产交易平台,由火币、OKEx等56家资本共同领衔投资。BHT是BHEX平台币,总量21亿枚,未来会减少到10.5亿枚,BHT承载了BHEX生态系统的核心价值。[2020/4/9]
2.2流程
1.攻击者通过UniswapV2闪电贷借出6,360,000USDC。
2.用闪电贷借出的6,360,000USDC分成3份,去bHOME中进行2次重入攻击调用了3次lend()函数铸造共8,465,943.180104bHOME。
BHEX交易所BTC永续合约24小时行情播报:截至今日上午11:30,据BHEX交易所永续合约行情:BTC币本位合约报价8723.9美元,预测资金费率为0.0301%(多头付空头);BTCUSDT合约报价8724.0美元,预测资金费率为0.0345%(多头付空头)。
过去24小时BTC合约多空持仓人数比为2.26, BTC币本位合约交易总量10815万张,BTCUSDT合约交易总量9812万张。BTC永续合约主动买入量为4778万张,主动卖出量为4168万张。[2020/2/29]
3.将刚才重入获得的bHOME拿去销毁赎回获得7,336,924.998USDC。
4、归还闪电贷借出的6,360,000USDC,并支付19,716的手续费,最后将剩余的957,208.998USDC转入自己的账户。
行情 | FastTrack4期项目BHT开盘大涨245%:FastTrack 4期项目BHT于 10:00上线火币全球站并同时开通USDT、BTC和HT交易对,截至新加坡时间7月26日10:05,相对开盘价格,BHT开盘大涨245%,报约0.066 USDT。FastTrack是火币全球站的快捷上币通道,主要面向在其他主流交易所已形成市场价格的热门优质项目,投票所得HT全部销毁。[2019/7/26]
2.3细节
该次攻击事件重点在于lend()函数,由于合约https://etherscan.io/address/0x781ad73f140815763d9a4d4752daf9203361d07d#code并未验证开源,所以我们只能从交易的Debugger中寻找线索。
1、攻击者通过UniswapV2闪电贷借出6,360,000USDC。
2、用闪电贷借出的6,360,000USDC分成3份,去bHOME中进行重入攻击2次调用?lend()函数铸造共8,465,943.180104bHOME。
3、将刚才重入获得的bHOME拿去销毁赎回获得7,336,924.998USDC。
4、归还闪电贷借出的6,360,000USDC,并支付19,716的手续费,最后将剩余的957,208.998USDC转入自己的账户。
2.3细节
该次攻击事件重点在于?lend()?函数,由于合约?https://etherscan.io/address/0x781ad73f140815763d9a4d4752daf9203361d07d#code?并未验证开源,所以我们只能从交易的Debugger中寻找线索。
分析Debugger可以看到下图是第一次调用函数,接着进行了2次重入。
从重入攻击中可以找到INPUT中调用函数的字节码为?0xa6aa57ce。
通过字节签名可以知道重入攻击调用的是?lend()?函数。
从Debugger中我们可以发现攻击合约的地址?0x781ad73f140815763d9a4d4752daf9203361d07d。
通过反编译合约?0x781ad73f140815763d9a4d4752daf9203361d07d?得到合约伪代码内容,可以找到?lend()?函数。
我们在反编译的代码中可以看到该合约使用的ERC777协议,会查询?recipient?的回调合约并回调?tokensReceived()?函数用以重入攻击。
通过分析可以发现?_index?就是传入的USDC数量。
totalSupply?和?balanceOf?的增量都和?_index?是正比关系,和?stor104?是反比关系,并且这两个变量的更新发生在重入攻击之前,每次都会更新。
stor104?记录的是用户存入的USDC总量,该变量的更新发生在重入之后,那么在重入的过程中?stor104?的值是不变的,而上面的?totalSupply?是在变大,所以最后return的值也会相应的增大,从而使得攻击者通过重入攻击铸造得到比正常逻辑更多的bHOME代币。
除了该次攻击事件,BlockSecTeam还阻断了后面发生的攻击并将金额返还给了项目方。
交易hash:0xf3bd801f5a75ec8177af654374f2901b5ad928abcc0a99432fb5a20981e7bbd1
3、总结
此次攻击事件是由于项目方使用了ERC777协议但没有对回调合约的安全性进行考虑从而导致了重入攻击的发生,当项目合约有涉及资产的转移时,建议使用「检查-生效-交互」模式来保证逻辑代码的安全,当然我们也可以使用OpenZeppelin官方提供的ReentrancyGuard修饰器来防止重入攻击的发生。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。