📢 Gate廣場獨家活動: #PUBLIC创作大赛# 正式開啓!
參與 Gate Launchpool 第 297 期 — PublicAI (PUBLIC),並在 Gate廣場發布你的原創內容,即有機會瓜分 4,000 枚 $PUBLIC 獎勵池!
🎨 活動時間
2025年8月18日 10:00 – 2025年8月22日 16:00 (UTC)
📌 參與方式
在 Gate廣場發布與 PublicAI (PUBLIC) 或當前 Launchpool 活動相關的原創內容
內容需不少於 100 字(可爲分析、教程、創意圖文、測評等)
添加話題: #PUBLIC创作大赛#
帖子需附帶 Launchpool 參與截圖(如質押記錄、領取頁面等)
🏆 獎勵設置(總計 4,000 枚 $PUBLIC)
🥇 一等獎(1名):1,500 $PUBLIC
🥈 二等獎(3名):每人 500 $PUBLIC
🥉 三等獎(5名):每人 200 $PUBLIC
📋 評選標準
內容質量(相關性、清晰度、創意性)
互動熱度(點讚、評論)
含有 Launchpool 參與截圖的帖子將優先考慮
📄 注意事項
所有內容須爲原創,嚴禁抄襲或虛假互動
獲獎用戶需完成 Gate廣場實名認證
Gate 保留本次活動的最終解釋權
Jarvis Network遭閃電貸重入攻擊 損失66.3萬MATIC
Jarvis Network項目遭受閃電貸重入攻擊分析
2023年1月15日,Jarvis_Network項目在Polygon網路上遭遇攻擊,造成約66.3萬MATIC的損失。分析顯示,攻擊者利用了閃電貸和重入漏洞進行攻擊。
攻擊交易調用棧分析顯示,在重入過程中,對同一合約的同一函數調用時,傳入參數相同但返回值卻有顯著差異。重入前後的返回值分別爲:
重入發生在remove_liquidity函數中。該函數在移除流動性時會將用戶添加的代幣返回。由於Polygon與EVM兼容,在MATIC轉帳給合約時觸發了重入。
深入分析發現,問題出在getUnderlyingPrice函數的實現上。該函數涉及到一系列內部計算和外部調用,其中關鍵是get_virtual_price函數的返回值。這個函數的返回值受self.D變量影響,而self.D的更新發生在代幣轉帳之後。
攻擊者在移除流動性時,MATIC轉移到攻擊合約後,通過回調先查詢了代幣價格。由於self.D尚未更新,導致價格獲取錯誤。攻擊者利用這個時間差,在重入時將借貸價格提高了約10倍。
雖然remove_liquidity函數使用了@nonreentrant('lock')裝飾器來防止重入,但攻擊者通過跨合約重入繞過了這一保護機制。
這次攻擊暴露了幾個關鍵問題:
爲防止類似攻擊,建議項目方:
通過這些措施,可以顯著提高項目的安全性和穩定性。