慢雾:详解 DeFi 协议 bZx 二次被黑

本文作者:yudan@慢雾安全团队

前言

今早,bZx 疑似遭遇第二次攻击,不同的是本次的对象是 ETH/sUSD 交易对,但也许有人会有疑问,sUSD 不是对标 USD 的稳定币吗?这都能被攻击?攻击手法具体是怎样的?带着这样的疑问,针对此次事件,慢雾安全团队接下来将复盘这两次攻击过程。

在第一次攻击中,攻击者结合 Flash loan 和 Compound 中的贷款,对 bZx 实施攻击,主要分成以下几步:

从 dYdX 借了 10000 个 ETH

到 Compound 用 5500 ETH 借了 112个 BTC 准备抛售

到 bZx 中用 1300个 ETH 开 5 倍杠杆做空,换了 51.345576 个 BTC,而这里换取的 BTC 是通过 Kyber Network 来获取价格的,然而 Kyber Network 最终还是调用 Uniswap 来获取价格,5 倍杠杆开完后兑换回来的 51 个 BTC 实际上是拉高了 UniSwap 中 BTC/ETH 的价格,换取价格是 1/109,但是实际上大盘的价格不会拉到这么多

用从 Compound 借来的 112 个 BTC 来在 UniSwap 中卖掉,由于第三步中 bZx 中的 5 倍杠杆已经把价格拉高,所以这个时候出售 ETH 肯定是赚的,然后卖了 6871 个 ETH

纽约市长:支持加密货币,而不是加密货币挖矿:金色财经报道,纽约市对加密货币友好的市长埃里克·亚当斯( Eric Adams)在奥尔巴尼与民选官员举行的地方政府预算听证会上表示反对加密货币开采。亚当斯表示,我支持加密货币,而不是加密货币挖矿。纽约州议员 Anna Kelles 博士称赞 Adams 区分了加密货币和加密货币的开采。她补充说,纽约市可以在不支持破坏环境的加密采矿的情况下成为美国的加密首都。

此前报道,亚当斯接受比特币和以太坊支付他的第一笔薪水,这两种工作量证明 (PoW) 加密货币依赖于能源密集型采矿。(u.today)[2022/2/10 9:42:49]

归还 dYdX 中的借贷

第二次攻击与之前稍有不同,但核心都在于控制预言机价格,并通过操纵预言机价格获利。

注: 下文中出现的 WETH 是 ETH 的 token 化代币,可统一认为是 ETH。与 ETH 之间的兑换比例是 1:1

细节剖析

本次发生攻击的交易哈希为:

0x762881b07feb63c436dee38edd4ff1f7a74c33091e534af56c9f7d49b5ecac15通过 etherscan 上的分析,我们看到这笔交易中发生了大量的 token 转账。

Gate.io“天天理财”第207期 ETH锁仓理财明日开启:据官方公告,Gate.io 将于5月6日(明日)12:00上线第207期 ETH锁仓理财,总额度 6,000 ETH,锁仓期限7天。[2021/5/5 21:26:19]

这么多转账交易中,攻击者一共购买了 20 次 sUSD,最终获利离场,那么攻击者具体是怎么操作的呢?我们使用区块浏览器 bloxy.info 来做进一步分析。

1、赛前准备

和第一次一样,首先攻击者需要从 Flash loan 借入一定的金额开始本次的攻击,第一次攻击是从 dYdX 借入 10000 ETH,这次,攻击者选择从 bZx 本身支持的 Flash loan 下手,借入 7500个 ETH。

2、发球

在完成从 bZx 的借入之后,攻击者开始通过 Kyber 进行 sUSD 的买入操作,第一次使用了 540 个 ETH 购买了 92,419.7 个 sUSD, 这个操作令 WETH/sUSD 的价格瞬间拉低,捧高了 sUSD 的价格。这次的交易兑换的比例大概为 1:170,而 Kyber 最终是通过 UniSwap 来进行兑换的,所以此时 Uniswap 的 WETH/sUSD 处于低位,反过来,sUSD/WETH 升高。

BTC突破25600美元关口 日内涨幅为6.6%:火币全球站数据显示,BTC短线上涨,突破25600美元关口,现报25605.69美元,日内涨幅达到6.6%,行情波动较大,请做好风险控制。[2020/12/27 16:37:07]

在完成第一次的 540 个ETH的兑换之后,攻击者再次在 Kyber 进行 18 次小额度的兑换,每次使用 20 个 ETH 兑换 sUSD,从 etherscan 我们能够看到,每一次的兑换回来的 sUSD 金额在不断减少。

这表明 sUSD/WETH 的价格被进一步拉升,这加剧了 Uniswap 中 sUSD/WETH 的价格,此时价格已经达到顶峰了,大概是 1:157。

在完成以上两步操作之后,攻击者已经完成狩猎前的准备,随时可以开始攻击。

3、一杆进洞

在完成对 sUSD/WETH 的拉升后,攻击者此时需要采集大量的 sUSD,为后续兑换 WETH 做准备。为了达成这个目的,攻击者向 Synthetix 发起 sUSD 的购买,通过向 Synthetix 发送 6000 ETH 购买 sUSD,直接把 Synthetix 中的 sUSD 买空,Synthetix 合约返还 2482 个 ETH 给攻击者。

完成了上面的操作后,攻击者直接对 bZx 发动总攻,直接用之前操作得来的一共 1,099,841 个 sUSD 向 bZx 兑换 WETH,此时由于 bZx 兑换还是要去查询 Uniswap 的 sUSD/WETH 的价格,而这个价格已经被攻击者人为拉得很高了,此时兑换,就能通过 1,099,841 个 sUSD 换取大量的 WETH, 此次交易一共用 1,099,841 个 sUSD 换取了 6792 个 WETH,此时攻击已经完成。

4、归还借贷

完成了对 bZx 的攻击之后,将 7500 ETH 归还给 bZx, 完成闪电贷流程,从 bZx 来,再回到 bZx 去,还使 bZx 遭受了损失。

赛后复盘

通过分析攻击者的攻击手法,我们统计下攻击者在攻击过程中的支出和收入情况。

7500 => bZx 闪电贷+2482 => Synthix 返还+6792 => 使用 sUSD 在 bZX 兑换 WETH=16774 ETH支出

540 + (20*18) => 拉高 sUSD/WETH 价格+6000  => 买空sUSD+7500 => 归还bZx闪电贷=14400 ETH总的收益为: 16774 - 144002374 = 2374 ETH

防御建议

两次攻击的主要原因还是因为 Uniswap 的价格的剧烈变化最终导致资产的损失,这本该是正常的市场行为,但是通过恶意操纵市场,攻击者可通过多种方式压低价格,使项目方造成损失。针对这种通过操纵市场进行获利的攻击,慢雾安全团队给出如下建议:

项目方在使用预言机获取外部价格的时候,应设置保险机制,每一次在进行代币兑换时,都应保存当前交易对的兑换价格,并与上一次保存的兑换价格进行对比,如果波动过大,应及时暂停交易。防止市场被恶意操纵,带来损失。

慢雾导航

慢雾科技官网

https://www.slowmist.com/

慢雾区官网

https://slowmist.io/

慢雾 GitHub

https://github.com/slowmist

Telegram

https://t.me/slowmistteam

Twitter

https://twitter.com/@slowmist_team

Medium

https://medium.com/@slowmist

币乎

https://bihu.com/people/586104

知识星球

https://t.zsxq.com/Q3zNvvF

火星号

http://t.cn/AiRkv4Gz

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

链链资讯

TUSD疫情启示录:现代化的脆弱与现代性的反思

2月14日,数字资产研究院、苇草智酷和零壹财经·零壹智库联合举办了以“现代化的脆弱和现代性的反思”为主题的线上沙龙活动。 数字资产研究院学术与技术委员会主席、苇草智酷创始合伙人朱嘉明,数字资产研究院理事长黄江南,苇草智酷创始合伙人、信息社会50人论坛执行主席段永朝以及数字资产研究院学术与技术委员会委员、东方证券首席经济学家邵宇进行了主题分享。

OKB法院默许Gram代币属于证券?Telegram对抗监管之路即将结束

作者 | Andrea Tinianow 翻译 | 罗远航 导语: 在出售数字资产当事方并未被指控为欺诈的情况下,联邦法院第一次提供机会让当事双方就构成“投资合同”的购买协议所依据的数字资产是否应被视为证券的情况进行辩护。Telegram 与 SEC 的诉讼将是加密货币监管历史上最重要的事件之一。

欧易交易所金色观察 | 减半矿币SERO信息全汇总 开年涨幅超500%

SERO项目资料 SERO系统是全球首创的,基于零知识证明技术实现隐私保护,并且能支持图灵完备智能合约运行的区块链基础设施平台。现实世界中组织的经济活动行为表明,缺乏隐私是广泛采用去中心化智能合约的主要障碍。比如企业供应链管理、金融交易、暗标拍卖、社交或网络购物行为等,有很多行为的过程其使用者认为是需要保密的。

Bitcoin风起于青萍之末:2020年Appchain生态预览

本文包含以下内容: ·Appchain是什么? ·已经有哪些Appchain了? ·Appchain在2020年会怎样? ·Appchain2020要做什么? 我们把面向特定应用开发的独立区块链称为Appchain,我们把基于智能合约平台开发的应用称为DApp。

[0:0ms0-3:418ms