当前位置:主页 > 区块链 > 资讯 > 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

    比特币

    $ 73135.88¥ 494808.1
    -1.21%
  • ethereum ETH 以太坊

    ETH

    以太坊

    $ 1986.19¥ 13437.76
    -2.15%
  • tether USDT 泰达币

    USDT

    泰达币

    $ 0.9988¥ 6.7574
    +0.01%
  • binance-coin BNB 币安币

    BNB

    币安币

    $ 693.04¥ 4688.83
    -5.58%
  • ripple XRP 瑞波币

    XRP

    瑞波币

    $ 1.3121¥ 8.8771
    -1.97%
  • usdc USDC USD Coin

    USDC

    USD Coin

    $ 1.0007¥ 6.7703
    -0.02%
  • solana SOL Solana

    SOL

    Solana

    $ 81.4243¥ 550.88
    -1.74%
  • tron TRX 波场

    TRX

    波场

    $ 0.3512¥ 2.376
    +1.12%
  • hyperliquid HYPE Hyperliquid

    HYPE

    Hyperliquid

    $ 73.5815¥ 497.82
    +6.01%
  • dogecoin DOGE 狗狗币

    DOGE

    狗狗币

    $ 0.1001¥ 0.6772
    -0.69%

币圈快讯

  • PeckShield:5月加密黑客攻击总损失8170万美元环比下降87.4%

    2026-06-01 15:52
    据PeckShield监测,5月加密领域共发生40起重大黑客攻击事件,总损失约8170万美元,较4月的6.47亿美元环比下降87.4%。其中跨链协议仍是主要攻击目标,8起重大跨链攻击造成3328万美元损失,占当月总损失的41%。 损失较大的事件包括SUPERFORTUNEAI(约1518万美元)、Verus-EthereumBridge(约1158万美元,已退还)、THORChain(约1000万美元)等。
  • TenArmor:检测到BSC上涉及AROS的可疑攻击损失约29.5万美元

    2026-06-01 15:39
    6月1日,据TenArmor监测,其已检测到BSC上涉及AROS的可疑攻击,损失约29.5万美元。
  • 黄金白银窄幅震荡Gate相关合约交易及持仓量位居全网前列

    2026-06-01 15:34
    金银开盘整体呈窄幅震荡、小幅回落的分化走势。据Gate平台数据,白银(XAG)现报75.85美元,24小时涨幅达0.64%;黄金(XAU)报4525.00美元,24小时涨跌幅为-0.27%。据Coinglass数据显示,GateXAG24小时合约成交额达5485.11万美元,持仓达5053.42万美元,均位居全网第二;GateXAU合约持仓规模达1.53亿美元,位列第二。 Gate首创金属合约交易板块,提供7×24小时不间断交易,为用户在波动行情下提供更高策略灵活性与资产管理效率。Gate合约已覆盖股票、金属、外汇、指数及大宗商品等多类传统金融资产,支持黄金、白银及全球热门股票等核心标的交易。Gate持续为全球用户打造更高效、专业的多资产一站式交易平台。
  • Gate预测市场BTC站稳7万美元预期占优冲击高位观点分化

    2026-06-01 15:32
    Gate预测市场最新数据显示,在“比特币是否会高于以下价位”相关预测中,BTC站上68,000美元和70,000美元的概率均接近100%,站上72,000美元的概率约为95%,显示多数参与者仍预期比特币将在7万美元附近及以上区间运行。不过,对于更高价格目标,市场观点出现明显分化。数据显示,BTC突破74,000美元的概率约为31%,而突破76,000美元的概率仅为2%,突破78,000美元的概率不足1%。当前市场对比特币维持现有价格区间相对乐观,但对于短期内进一步大幅上涨仍持谨慎态度。作为首家接入Polymarket的CEX平台,Gate目前已稳居第一,成为用户参与预测市场的重要入口,在用户参与规模、市场活跃度及生态影响力等方面保持领先优势。用户可通过GateApp直接访问预测市场,从平台首页Alpha进入Polymarket页面,使用交易所账户内USDT参与事件预测。Gate正不断扩大其在预测市场领域的影响力,为用户提供从预期判断到交易参与的多元化市场体验。
  • Hyperliquid平台鲸鱼当前持仓48.57亿美元多空持仓比为0.98

    2026-06-01 15:30
    据Coinglass数据,Hyperliquid平台鲸鱼当前持仓48.57亿美元,多单持仓24.03亿美元,持仓占比49.48%,空单持仓24.54亿美元,持仓占比50.52%。多单盈亏3,461.1万美元,空单盈亏-8,402.85万美元。 其中,巨鲸地址0x0ddf..02在69423.2美元价格3倍全仓做空BTC,目前未实现盈亏-496.26万美元。
  • 查看更多