Cointime

扫码下载App
iOS & Android

Hundred Finance攻击事件分析

根据Numen链上监控显示Apr-15-2023 02:12:00 PM +UTC时间,Hundred Finance遭到攻击,损失约600万美金。

攻击交易地址:

https://optimistic.etherscan.io/tx/0x6e9ebcdebbabda04fa9f2e3bc21ea8b2e4fb4bf4f4670cb8483e2f0b2604f451

攻击分析

根据调用栈分析如下:

1.攻击者首先调用aave的flashloan函数借出500wbtc。

2.首先观察到hwbtc没有人来进行借贷,只有很早之前攻击者的操作。

3.攻击者先redeem自己早期存入的wbtc,使hwbtc的totalsupply=0。

4.然后攻击者创建了最小代理合约,存入4个wbtc,根据计算获得200个hwbtc。

5.然后攻击者redeem到只剩2wei个wbtc。

6.此时攻击者创建的合约上有500wbtc和2wei hwbtc。

7.攻击者把500wbtc转入池子,此时的hwbtc价格变高,使其能获得借出大量eth的能力。

8.攻击者借出eth,又因为当前合约的solidity版本0.5.16,在计算时引入了计算库防止溢出,所以在redeemunderlying向下取整,赎回500wbtc只需要1wei hwbtc。

9.攻击者清算自己,通过清算再把hwbtc的totalsupply=0,重复上述操作攻击其它借贷池。

从代码角度分析,合约代码基本fork compound,根本问题是Hundred Finance的wbtc资产没有人来借贷,所以攻击者能控制totalsupply,攻击通过给池子转移资产,用极少的totalsupply对应大量的底层资产,是htoken的价格变高,提升借贷权利。

从和compound的diff看这都是正常逻辑,exchangrate确实变大。

下面这部分计算:

上述代码计算也没有问题。evm没有浮点数,默认向下取整。

所以在赎回的时候本需要2wei hwbtc,经过计算只需要1wei。

攻击的两个主要条件,hwbtc没有产生借贷,攻击者可控totalsupply,第二个条件就是上述说明的计算问题。

总结

此次事件的根本原因是 hwbtc没有用户产生借贷,导致黑客可以控制totalsupply,数据向下取整导致redeemunderlying可以全部赎回。如果能闪电贷能借的更多,攻击者持有的份额无限趋近去totalsuply也能完成攻击,但实际情况无法做到。

损失详情:

0.058 WBTC

20,854 枚 SNX

1,265,978枚USDC

842,788 枚 DAI

1,113,430枚USDT

865,142 枚 sUSD

457,286枚 FRAX

1,030枚ETH

评论

所有评论

推荐阅读

  • ITA 2026 首届RWA全球峰会倒计时2天

    2月7日消息,为探讨RWA(现实世界资产)前沿趋势,搭建政、经、产、学、研多方高端交流合作平台,紫荆杂志社联合RWA生态国际联合会、三角形科技(香港)有限公司、WebX全球数字控股集团、Coin Found等公司,将于2月9日在香港举办的“ITA 2026 首届RWA全球峰会”,倒计时2天。

  • BTC跌破68000美元

    行情显示,BTC跌破68000美元,现报67999.01美元,24小时涨幅达到4.86%,行情波动较大,请做好风险控制。

  • BTC跌破69000美元

    行情显示,BTC跌破69000美元,现报68957.16美元,24小时涨幅达到5.84%,行情波动较大,请做好风险控制。

  • 易理华转入交易所的ETH数量远超卸杠杆所需,疑似将全部清仓

    2月7日消息,链上分析师余烬于X发文表示,易理华地址看起来并非只是在卸杠杆,而是在清仓。目前,相关地址已经把63.04万枚ETH(12.94亿美元)转进了币安,链上现在仅剩下2.13万枚ETH(4394万美元)。96%的ETH都已经转进交易所,数量远超卸掉杠杆所需出售的数量,所以大概率是要全部清仓了。

  • ETH突破2000美元

    行情显示,ETH突破2000美元,现报2000.7美元,24小时跌幅达到3.93%,行情波动较大,请做好风险控制。

  • BTC突破68000美元

    行情显示,BTC突破68000美元,现报68000.01美元,24小时跌幅达到3.33%,行情波动较大,请做好风险控制。

  • BTC跌破67000美元

    行情显示,BTC跌破67000美元,现报66996.64美元,24小时跌幅达到4.65%,行情波动较大,请做好风险控制。

  • BTC突破67000美元

    行情显示,BTC突破67000美元,现报67006.7美元,24小时跌幅达到3.83%,行情波动较大,请做好风险控制。

  • BTC突破66000美元

    行情显示,BTC突破66000美元,现报66006.95美元,24小时跌幅达到7.87%,行情波动较大,请做好风险控制。