mt logoMyToken
总市值:
0%
恐慌指数:
0%
币种:--
交易所 --
ETH Gas:--
EN
USD
APP
Ap Store QR Code

Scan Download

甜蜜一击?谁是幕后黑手?BSC链上XSURGE遭闪电贷攻击全解析

收藏
分享

8月17日, 链必安-区块链安全态势感知平台(Beosin-Eagle Eye) 舆情监测显示,BSC链上DeFi协议 XSURGE 遭到闪电贷攻击,攻击者利用合约的重入漏洞获利超过13111BNB。关于本次攻击,成都链安技术团队第一时间进行了事件分析。

 

#1 事件概览

 

攻击如何发生 Event overview

DeFi项目XSURGE今日遭遇闪电贷攻击,不过在XSURGE在遭攻击前,官方发布了关于SurgeBNB漏洞的声明。

XSURGE表示,当地时间8月16日发现了SurgeBNB合约的潜在安全漏洞。由于SurgeBNB合约不可更改且已被放弃,因此无法追溯修补该代币。XSURGE没有透露任何关于此漏洞性质的具体细节,但强烈建议用户尽快迁移出SurgereBnb,因为该漏洞随时都可能被攻击者触发。

说时迟那时快, 在声明发布后,XSURGE随后便表示遭遇攻击,这甜蜜一击让项目方防不胜防。 官方称,攻击者通过后门漏洞在SurgeBNB中窃取了500万美元。由于SurgeUSD或SurgeETH不提取BNB,因此它们不能成为未来攻击的目标。

回到本次闪电贷攻击,让我们看看这一次的攻击者是如何实现「空手套白狼」的。

 

#2 事件具体分析

 

攻击者如何得手 Event overview

攻击者地址:

0x59c686272e6f11dC8701A162F938fb085D940ad3

攻击合约

以交易

0x8c93d6e5d6b3ec7478b4195123a696dbc82a3441be090e048fe4b33a242ef09d为例

round 0

先通过闪电贷借出10,000BNB。

Round 1

用所有的的BNB去购买SURGE,根据当前价格,能买到1,896,594,328,449,690 SURGE。

获取的SURGE

Round 2

调用sell函数卖出所获得的SURGE ,卖出了9346个BNB。

Round 3

因为sell函数是先转账后修改数据,且转账代码中存在重入漏洞。在攻击合约收到BNB时,SURGE合约的状态改变前(第595行代码),攻击合约可通过重入漏洞再次购买SURGE。

由于攻击合约每次都将所有BNB余额用于购买SURGE,合约的bnbAmount不变,而SURGE的代币总量_totalSupply未更新(仍为sell之前的数量),因此SURGE价格降低,导致攻击者可以买到更多的SURGE。

Round 4

重复3次Round2、Round3, 攻击者通过重入累积了大量的SURGE, 之后将所有的SURGE全部卖出便可以获利。

这笔交易的最后,攻击合约卖了1,864,120,345,279,610,000 SURGE,获得了10327 BNB,最后将获利的297 BNB发送给攻击者地址。

 

#3 事件复盘

 

我们需要注意什么 Case Review

对于本次攻击事件,成都链安技术团队给出的修改建议为: 1.为防止重入攻击,任何转账操作都应该发生在状态改变后;2.使用transfer或send进行转账,不要使用call.value。

在此类安全事件中,攻击者通常属于「空手套白狼」,先使用闪电贷获取大量资金,拥有了攻击的启动「砝码」后,再通过一系列手段出入各类抵押、借贷、交易等协议,在实现操纵、扭曲资产价格数据后,实施套利,最后归还「本金」。

?注意 ?

本次事件,攻击者利用合约的重入漏洞获利超过13111BNB,成都链安在此提醒各位用户注意风控,比如在官方发布关于SurgeBNB漏洞的声明后,要及时采取相应措施。

免责声明:本文版权归原作者所有,不代表MyToken(www.mytokencap.com)观点和立场;如有关于内容、版权等问题,请与我们联系。