当前位置:主页 > 区块链 > 资讯 > Prisma Finance被攻击事件分析

Prisma Finance被攻击事件分析吸取教训

2025-04-29 09:12:08 | 来源: | 作者:佚名
2024年3月28日,Prisma Finance遭受闪电贷攻击,项目方损失约1221万美元,SharkTeam针对此事件进行了技术分析,并总结了安全防范手段,希望后续项目可以引以为戒,共筑区块链行业的安全防线,一起来看看吧

一、攻击交易分析

攻击者1:0x7e39e3b3ff7adef2613d5cc49558eab74b9a4202(简记为0x7e39)

攻击合约1:0xd996073019c74b2fb94ead236e32032405bc027c(简记为0xd996)

攻击者2:0x7fe83f45e0f53651b3ed9650d2a2c67d8855e385

攻击合约2:0x4148310fe4544e82f176570c6c7b649290a90e17

被攻击的目标合约:0x1cc79f3f47bfc060b6f761fcd1afc6d399a968b6

攻击包含16笔交易,以第一笔攻击交易为例:

0x00c503b595946bccaea3d58025b5f9b3726177bbdc9674e634244135282116c7

攻击流程如下:

1. 读取地址0x56a201b872b50bbdee0021ed4d1bb36359d291ed(简记为0x56a2)在目标合约中的所有抵押物和债务。

返回结果如下:

地址0x56a2在目标合约中抵押物共有1,745 wstETH,总债务共有1,442,100 mkUSD。

2. 攻击者0x7e39通过攻击合约0xd996调用mkUSD债务合约中的flashLoan函数。

参数receiver设置为MigrateTroveZap,amount为上面查询到的全部债务。

然后,在flashLoan函数中会调用receiver(这里是MigrateTroveZap)中的onFlashLoan函数。

onFlashLoan函数通过闪电贷先偿还原来的所有债务,提取抵押物到receiver,然后receiver将一定数量的抵押物重新抵押,并借取一定的债务。其中主要调用了2个函数:

(1)closeTrove函数,偿还债务并将所有的抵押物(1745.08 swtETH)从troverManager提取到receiver(这里是MigrateTroveZap合约);

(2)openTrove函数,由receiver将463.18 wstETH重新抵押到troverManager中,并负债1,443,598 mkUSD。

从上面数据可以看出,flashLoan函数执行完成后,receiver中仍然保留了从troverManager中提取的属于地址0x56a2的抵押物,数量约为1745.08 – 463.18 = 1281.90 wstETH。

3. 攻击者0x7e39通过攻击合约0xd996从Balancer中通过闪电贷借取了1 wstETH。

然后,抵押1 wstETH并借取债务2000 mkUSD,加上fee,共计负债2200 mkUSD。

4. 与步骤2类似,调用mkUSD债务合约中的flashLoan函数,这里参数receiver仍然设置为MigrateTroveZap,amount为上一笔质押1 wstETH后的全部债务,即2000 mkUSD。在FflashLoan函数中会调用receiver中的onFlashLoan函数,然后调用closeTrove和openTrove函数。

只是,这里closeTrove和openTrove函数中的参数account不再是上面的地址0x56a2,而是质押了1 wstETH的攻击合约0xd996。

(1)closeTrove函数,偿还债务并将所有的抵押物(1 swtETH)从troverManager提取到receiver(这里仍然是MigrateTroveZap合约)。此时receiver中共有1281.90 +1=1282.90 wstETH.

(2)openTrove函数,由receiver将1282.80 wstETH(几乎全部)重新抵押到troverManager中,并负债2001.8 mkUSD。

实际上,这里抵押物中1281.80 wstETH是不属于攻击合约0xd996,而是属于上面的地址0x56a2。

5. 最后,攻击者0x7e39通过攻击合约0xd996单独调用closeTrove函数,将抵押的1282.80 wstETH 提取到了攻击合约0xd996中。

偿还闪电贷后,攻击者仍获利1281.80 wstETH,约2.30M USD。

二、漏洞分析

本次事件的根本原因是项目合约存在逻辑和权限校验,使得攻击者可以利用该漏洞获取其他账户地址的质押资产。

攻击者最终获得的wstETH是原本地址0x56a2在troverManager合约中的抵押物,通过mkUSD合约的flashLoan函数,自定义MigrateTroveZap合约中onFlashLoan函数的参数,利用 MigrateTroveZap将其转变为攻击合约的抵押物,然后将其提取出来。

攻击者通过mkUSD合约中的flashLoan函数以及MigrateTroveZap合约中的onFlashLoan函数操纵其他账户地址的抵押和提取。

(1)flashLoan函数中缺少对参数receiver地址的校验,因为onFlashLoan函数中receiver会接收account的所有抵押物,因此需要对receiver进行可信的校验;

(2)onFlashLoan函数中缺少对account地址的校验,因为closeTrove和openTrove函数都是操作的account的资产,因此需要对account增加权限方面的校验;

除了对这两个地址参数的校验外,可能还需要对flashLoan函数中的数量参数以及实现逻辑进行校验。

三、安全建议

针对本次攻击事件,我们在开发过程中应遵循以下注意事项:

(1)项目在设计和开发过程中,要保持逻辑的完整性和严谨性,尤其是涉及到资产的转移过程中,更要加强对函数调研权限的校验,保证调用者、调用函数、函数参数、转账逻辑等都是安全可信的。

(2)项目上线前,需要找专业的第三方审计团队进行合约审计。

关于 SharkTeam

SharkTeam的愿景是保护Web3世界的安全。团队由来自世界各地的经验丰富的安全专业人士和高级研究人员组成,精通区块链和智能合约底层理论。提供包括风险识别与阻断、智能合约审计、KYT/AML、链上分析等服务,并打造了链上智能风险识别与阻断平台ChainAegis,能有效对抗Web3世界的高级持续性威胁(Advanced Persistent Threat,APT)。已与Web3生态各领域的关键参与者,如Polkadot、Moonbeam、polygon、Sui、OKX、imToken、Collab.Land等建立长期合作关系。

免责声明:本文只为提供市场讯息,所有内容及观点仅供参考,不构成投资建议,不代表本站观点和立场。投资者应自行决策与交易,对投资者交易形成的直接或间接损失,作者及本站将不承担任何责任。!
Tag:Finance   Prisma  
更多

热门币种

  • 币名
    最新价格
    24H涨幅
  • bitcoin BTC 比特币

    BTC

    比特币

    $ 67809.2¥ 468425.95
    +1.13%
  • ethereum ETH 以太坊

    ETH

    以太坊

    $ 1972.58¥ 13626.58
    +1.26%
  • tether USDT 泰达币

    USDT

    泰达币

    $ 0.9997¥ 6.9059
    +0.01%
  • ripple XRP 瑞波币

    XRP

    瑞波币

    $ 1.4235¥ 9.8335
    +0.81%
  • binance-coin BNB 币安币

    BNB

    币安币

    $ 628.43¥ 4341.19
    +3.27%
  • usdc USDC USD Coin

    USDC

    USD Coin

    $ 1.0017¥ 6.9197
    -0.01%
  • solana SOL Solana

    SOL

    Solana

    $ 84.451¥ 583.38
    +3.04%
  • tron TRX 波场

    TRX

    波场

    $ 0.2859¥ 1.9749
    +0.39%
  • dogecoin DOGE 狗狗币

    DOGE

    狗狗币

    $ 0.1005¥ 0.6942
    +2.59%
  • bitcoin-cash BCH 比特现金

    BCH

    比特现金

    $ 559.35¥ 3863.98
    +0.06%

币圈快讯

  • Brickken调查:RWA发行机构优先考虑资本形成而非流动性

    2026-02-21 05:29
    代币化平台Brickken发布的一份2025年第四季度最新调查显示,大多数现实世界资产(RWA)发行商正在使用代币化来筹集资金,而不是释放二级市场流动性。在受访者中,53.8%表示提高资本形成和融资效率是他们进行代币化的主要原因,而15.4%表示流动性需求是他们的主要动机。另有38.4%表示不需要流动性,而46.2%表示他们预计在6到12个月内实现二级市场流动性。
  • 某比特币OG再次向Binance存入6318枚比特币

    2026-02-21 04:56
    据OnchainLens数据,BitcoinOG再次向Binance存入6,318枚比特币,价值4.2486亿美元。迄今为止,它已向Binance累计存入11,318枚比特币,价值7.6061亿美元。
  • MillerValuePartners将Strategy持股比例增加到25250股

    2026-02-21 04:39
    据BitcoinTreasuries.NET监测,传奇投资者比尔·米勒的投资管理公司MillerValuePartners将其在比特币资金管理公司Strategy$MSTR的持股比例增加了65%,达到25,250股(340万美元)。
  • BREV涨超11%JUP涨超7%

    2026-02-21 04:30
    据币安现货数据显示,市场出现大幅波动。BREV24小时涨幅11.08%,JUP24小时涨幅7.66%,并触及今日新高。同时,SYN、JTO、TRUMP、DOLO、MITO均出现“冲高回落”状态,分别跌幅5.44%、6.64%、6.31%、6.11%、5.6%。NOM则在2小时内小幅下跌10.1%。
  • 某钱包将价值260万美元PUMP代币转移至Bitget

    2026-02-21 04:16
    据Onchainschool监测,大约三小时前,一个此前从团队钱包接收过PUMP的钱包将价值260万美元的代币转移至Bitget。这是该钱包7个月未进行任何操作后的首笔大额转账。该钱包目前仍持有价值750万美元的代币,未来也可能被提取至交易所。
  • 查看更多