🎉 攢成長值,抽華爲Mate三折疊!廣場第 1️⃣ 2️⃣ 期夏季成長值抽獎大狂歡開啓!
總獎池超 $10,000+,華爲Mate三折疊手機、F1紅牛賽車模型、Gate限量週邊、熱門代幣等你來抽!
立即抽獎 👉 https://www.gate.com/activities/pointprize?now_period=12
如何快速賺成長值?
1️⃣ 進入【廣場】,點擊頭像旁標識進入【社區中心】
2️⃣ 完成發帖、評論、點讚、發言等日常任務,成長值拿不停
100%有獎,抽到賺到,大獎等你抱走,趕緊試試手氣!
截止於 8月9日 24:00 (UTC+8)
詳情: https://www.gate.com/announcements/article/46384
#成长值抽奖12期开启#
Euler Finance遭1.97億美元閃電貸攻擊 donateToReserves函數存漏洞
Euler Finance遭受閃電貸攻擊,損失近2億美元
2023年3月13日,Euler Finance項目遭遇了一次重大的閃電貸攻擊。根據鏈上監控數據顯示,攻擊者利用項目合約中的一個漏洞,成功竊取了約1.97億美元的資金,涉及6種不同的代幣。
攻擊過程分析
攻擊者首先從某借貸平台獲取了3000萬個DAI的閃電貸,隨後部署了兩個關鍵合約:一個用於借貸操作,另一個用於清算。
攻擊的主要步驟如下:
將2000萬DAI質押到Euler Protocol合約中,獲得19.5百萬eDAI。
利用Euler Protocol的10倍槓杆功能,借出195.6百萬eDAI和200百萬dDAI。
使用剩餘的1000萬DAI償還部分債務,並銷毀相應的dDAI。
再次借出同等數量的eDAI和dDAI。
通過donateToReserves函數捐贈100百萬eDAI,隨後調用liquidate函數進行清算,獲得310百萬dDAI和250百萬eDAI。
最後提取38.9百萬DAI,歸還30百萬閃電貸,淨利潤約8.87百萬DAI。
漏洞原因分析
此次攻擊的核心漏洞在於Euler Finance合約中的donateToReserves函數缺少必要的流動性檢查。與其他關鍵函數(如mint函數)相比,donateToReserves函數未執行checkLiquidity操作,這導致攻擊者能夠操縱自身帳戶狀態,使其符合被清算的條件。
正常情況下,checkLiquidity函數會調用RiskManager模塊,確保用戶的eToken數量始終大於dToken數量。然而,由於donateToReserves函數缺少這一關鍵步驟,攻擊者得以繞過安全機制,實現不當獲利。
安全建議
針對此類攻擊,區塊鏈項目方應當:
在合約上線前進行全面的安全審計,確保代碼質量和安全性。
特別關注借貸類項目中的資金償還、流動性檢測和債務清算等關鍵環節。
確保所有可能影響用戶資產狀態的函數都包含必要的安全檢查步驟。
定期進行代碼review和漏洞掃描,及時修復潛在風險。
考慮引入多重籤名機制或時間鎖等額外安全措施,爲應對緊急情況預留緩衝時間。
此次事件再次凸顯了智能合約安全的重要性。項目方應當始終將安全置於首位,通過持續的安全實踐和技術創新,共同構建更加安全、可靠的Web3生態系統。