元宇宙非小号金色财经交流群社区官网

DeFi协议Akropolis被盗200万美元 被PeckShield技术拆解揭秘

浏览:68|时间:2023-08-25 05:29:20
黑客利用Akropolis合约漏洞连续实施了17次重入攻击,导致其yCurve和sUSD资金池损失了203万枚DAI。

原文标题:《DeFi协议Akropolis漏洞详解:黑客复现「经典重入攻击」掳走203万DAI》 撰文:PeckShield

昨天晚间19时50分,DeFi协议Akropolis遭到了黑客攻击。

区块链安全公司PeckShield(派盾)安全人员迅速定位到问题在于,Akropolis项目的SavingsModule合约在处理用户存储资产时存在某种缺陷,黑客利用此缺陷连续实施了17次重入攻击,导致其YCurve和sUSD资金池损失了203万枚DAI。

技术概要

本次攻击的原因如下: 1. 合约没有对用户存储的Token进行白名单校验 2. 关键的deposit函数没有对重入攻击的保护

简单而言:黑客利用Akropolis项目存在的存储资产校验缺陷,向合约发起连续多次的重入攻击,致使Akropolis合约在没有新资产注入的情况下,凭空增发了大量的pooltokens,进而再利用这些pooltokens从YCurve和sUSD池子中提取DAI,最终导致项目合约损失了203万枚DAI。

攻击过程详解

攻击流程复现: 我们通过分析黑客实施攻击的交易哈希(0xe1f375a47172b5612d96496a4599247049f07c9a7d518929fbe296b0c281e04d) 发现,攻击来自于一个恶意的ERC20合约地址(0xe2307837524Db8961C4541f943598654240bd62f)

这个恶意合约实现了一个钩子函数,使得函数在transferFrom(functionsignature:0x23b872dd)被调用的时候会被执行。

攻击者先是调用SavingsModule.sol中的deposit函数,并将自己编写的位于0xe230开头的恶意合约其钩子函数会再次调用deposit函数并存入真实的DAI资产。

由于pooltokens增发的量通过代币deposit前后余额的差值得出。所以第二次deposit的真实的DAI资产会被计算两次用于铸造pooltokens。第一次是在恶意合约0xe230存储的时候,第二次是在DAI存储的时候。也就是说,如果第二次存储的时候存入了25KDAI,那么由于重入攻击,总的铸造的pooltokens将会是双倍,也就是50KDAI。

以此类推,黑客总共发起17次重入攻击并获得了总共2,030,841.0177个DAI资产。

值得注意的是,在攻击的最开始,攻击者还使用了dYdX的闪贷功能。

核心漏洞详解

接下来,我们分析下存在漏洞的代币存储逻辑。Akropolis的用户可以将代币存储入DelphiSavingsPools,而资金池会铸造相应的pooltokens给用户。核心逻辑在SavingsModule::deposit(1,944行)。

第一步:攻击者调用deposit函数并提供_tokens参数。这个函数在进一步调用depositToProtocol(_protocol,_tokens,_dnAmounts)前后会计算代币的余额,并通过代币余额的变化来决定将要铸造的poolTokens数目(第1,970行)。而depositToProtocol函数会调用目标代币的safeTransferFrom函数来进行代币的转账(第2,004行)。然而deposit函数没有对重入攻击进行检测,也没有检查存入的代币是否为恶意代币;

第二步:在恶意代币的transferFrom函数被调用的时候,触发钩子函数,从而再次调用deposit函数;

第三步:因为第二次调用deposit函数的时候攻击者存入了真正的DAI代币使得池子的代币余额发生变化,所以攻击者可以获得资金池铸造的poolTokens;

第四步:当第二次deposit函数调用结束的时候,代码执行流程将返回第一次存储代币调用depositToProtocol函数的上下文。这个时候,代币余额变化将被再次计算。此时代币余额的变化和第二次调用deposit函数代币余额变化一样。因此攻击者可以再次获得相应数目的poolTokens。

被盗资产情况

这次攻击的被盗资产目前被存储在钱包0x9f26中。PeckShield旗下数字资产追踪平台CoinHolmes正在对该地址做全方位监控,并对其资金流向做进一步的锁定分析和追踪,以便协助项目方挽回被盗资产。

DeFi Hi op polis 技术

  • Optimism (OP) 简介:OP币是山寨币吗?

    Optimism (OP) 简介:OP币是山寨币吗?

    2022-07-20 13:50:23

    Optimism 是第一个开发与以太坊虚拟机 (EVM) 兼容的 Optimistic Rollup 解决方案的以太坊 L2。Optimism 与以太坊并行,能够在继承以太坊安全性的同时大规模处理交易。Optimisti...

  • Optimism(OP)币未来如何?2023年op币投资攻略

    Optimism(OP)币未来如何?2023年op币投资攻略

    2023-03-21 19:31:26

    Optimism 是以太坊最大的扩容解决方案之一,OP 币为其原生治理代币,也是第一个rollup 代币。Optimism 代币OP 是2023 年初表现最好的加密货币之一,其涨幅高达227%,相对于以太坊上涨了135%...

  • HOPE生态借贷协议HopeLend公测开启,推出20,000 $HOPE激励活动

    HOPE生态借贷协议HopeLend公测开启,推出20,000 $HOPE激励活动

    2023-07-20 18:04:25

    分布式稳定币项目 HOPE.MONEY 去中心化借贷协议 HopeLend 已于 7 月 20 日在以太坊 Sepolia 测试网开启公测,并计划在近期上线主网。作为 HOPE 生态的第二个协议,HopeLend 为分布...

  • Optimism空投在即,OP币会重新开始一轮币圈热潮吗?

    Optimism空投在即,OP币会重新开始一轮币圈热潮吗?

    2022-06-01 20:07:56

    Optimism,迄今为止最受重视的Layer2扩充计划方案之一,投资机构有A16z、Paradim,称得上顶尖。用心薅过羊毛绒的应当都是有那么一个形象化体会:大中型组织投资的项目要不不空投物资,一旦空投,其幅度肯定是不...

本站分享的区块链、Web3.0元宇宙、NFT、数字藏品最新消息等相关数藏知识快讯NFR资讯新闻,与金色财经非小号巴比特星球前线Btc中国官网无关,本站资讯观点不作为投资依据,市场有风险,投资需谨慎!不提供社区论坛BBS微博微信交流群等相关币圈信息发布!
声明:本站内容来源于网络,如有侵权请即时告知,我们将即时删除!