📢 Gate广场专属 #WXTM创作大赛# 正式开启!
聚焦 CandyDrop 第59期 —— MinoTari (WXTM),总奖池 70,000 枚 WXTM 等你赢!
🎯 关于 MinoTari (WXTM)
Tari 是一个以数字资产为核心的区块链协议,由 Rust 构建,致力于为创作者提供设计全新数字体验的平台。
通过 Tari,数字稀缺资产(如收藏品、游戏资产等)将成为创作者拓展商业价值的新方式。
🎨 活动时间:
2025年8月7日 17:00 - 8月12日 24:00(UTC+8)
📌 参与方式:
在 Gate广场发布与 WXTM 或相关活动(充值 / 交易 / CandyDrop)相关的原创内容
内容不少于 100 字,形式不限(观点分析、教程分享、图文创意等)
添加标签: #WXTM创作大赛# 和 #WXTM#
附本人活动截图(如充值记录、交易页面或 CandyDrop 报名图)
🏆 奖励设置(共计 70,000 枚 WXTM):
一等奖(1名):20,000 枚 WXTM
二等奖(3名):10,000 枚 WXTM
三等奖(10名):2,000 枚 WXTM
📋 评选标准:
内容质量(主题相关、逻辑清晰、有深度)
用户互动热度(点赞、评论)
附带参与截图者优先
📄 活动说明:
内容必须原创,禁止抄袭和小号刷量行为
获奖用户需完成 Gate广场实名
Jarvis Network遭受闪电贷重入攻击 损失663,101 MATIC
Jarvis Network项目遭遇闪电贷重入攻击分析
2023年1月15日,Jarvis_Network项目遭受攻击,损失663,101个MATIC。通过对攻击交易的调用栈分析,发现存在重入逻辑。在重入过程中,对同一合约的同一函数调用,传入参数相同,但返回值差异巨大。
重入发生在remove_liquidity函数中。该函数在移除流动性时会将用户添加的代币返回。由于Polygon与EVM同构,MATIC转账给合约时会触发重入。
深入分析发现,问题出在getUnderlyingPrice函数的实现上。该函数涉及多个合约调用,最终影响get_virtual_price函数的返回值。get_virtual_price函数的返回值受self.D变量影响,而self.D的更新在转账之后进行。
攻击者在移除流动性时,MATIC转移到攻击合约后,回调fallback函数查询价格。由于self.D更新在转账之后,导致之前的价格获取错误。移除流动性方法流程为:1)销毁用户LP;2)发送用户质押资金;3)更新self.D。
self.D用于价格计算,添加流动性时也会更新。攻击者的流动性资金较大,正常情况下self.D值会小很多。但攻击者在步骤2进行重入,并以高于原始价格10倍的价格进行借贷。这是因为self.D值在添加流动性时增大,而移除流动性时未及时更新。
虽然remove_liquidity方法使用了@nonreentrant('lock')防止重入,但攻击者重入进入其他合约借贷资金,使重入锁失效。
此次攻击主要原因是变量修改逻辑在外部调用之后,导致价格获取异常。跨合约重入使重入锁失效。建议项目方进行严格的安全审计,将变量修改放在外部调用之前,采用多数据源的价格获取方式。遵循"先判断,后写入变量,再进行外部调用"的编码规范(Checks-Effects-Interactions)可以提高项目安全性和稳定性。