危險的授權轉账:Li.Finance 攻擊事件始末

2022-03-22 21:03:03

前言

北京時間3月20日晚,知道創宇區塊鏈安全實驗室 監測到以太坊上分布式跨鏈協議。Li.Finance 受到了攻擊,攻擊者執行了 37 次call注入,獲取了多個錢包中約 60 萬美元的資產(204個ETH)。此次資產損失並沒有非常大,但項目方對於攻擊的處理非常積極並值得學習與肯定(見後文),目前項目方已補償了協議損失並修復後重新部署了協議。

知道創宇區塊鏈安全實驗室 第一時間跟蹤本次事件並分析。


      危險的授權轉账:Li.Finance 攻擊事件始末

分析

1.攻擊者相關信息

攻擊tx:

0x4b4143cbe7f5475029cf23d6dcbb56856366d91794426f2e33819b9b1aac4e96

被攻擊合約:

0x5A9Fd7c39a6C488E715437D7b1f3C823d5596eD1--代理合約

0x73a499e043b03fc047189ab1ba72eb595ff1fc8e--邏輯合約

攻擊者地址:  

0xC6f2bDE06967E04caAf4bF4E43717c3342680d76 -- 部署地址

0x878099F08131a18Fab6bB0b4Cfc6B6DAe54b177E -- 收款地址

2.攻擊流程

攻擊調用流程

攻擊者構造 payload 並調用被攻擊合約 0x5a9fd7c3 的 swapAndStartBridgeTokensViaCBridge 函數:


      危險的授權轉账:Li.Finance 攻擊事件始末

具體使用的 Payload 如下--圖中選中部分即為利用授權轉账(transferFrom)部分的 payload:


      危險的授權轉账:Li.Finance 攻擊事件始末

調用一次正常50刀的跨鏈橋功能(為了能正常調用 swapAndStartBridgeTokensViaCBridge 函數):


      危險的授權轉账:Li.Finance 攻擊事件始末

在 payload 中包括多個call方法(調實際用transferFrom)。讓 0x5a9fd7c3 調用 37 個call,借此利用多個錢包對於 0x5a9fd7c3 合約的授權(approve)將錢包資產轉账到攻擊者地址:


      危險的授權轉账:Li.Finance 攻擊事件始末

後續執行正常的跨鏈橋邏輯 _startBridge(_cBridgeData); 這也是為什么第一個 swap 是正常的,這樣才能讓後續邏輯正常執行下去:


      危險的授權轉账:Li.Finance 攻擊事件始末

3.漏洞細節

導致本次問題的根本原因被攻擊合約0x5a9fd7c3的邏輯合約存在一個批量讓call 調用傳入數據的函數 swapAndStartBridgeTokensViaCBridge:


      危險的授權轉账:Li.Finance 攻擊事件始末

該合約將會取出payload中的多個_swapData 數據結構並調用,LibSwap.swap(...);實現如下:


      危險的授權轉账:Li.Finance 攻擊事件始末

借此,攻擊者利用該合約的 call 將各個錢包對 0x5a9fd7c3 合約的代碼授權轉走了多個錢包中的各種代幣。


      危險的授權轉账:Li.Finance 攻擊事件始末

4.項目方進展

在事件發生後,項目方第一時間對合約可能的方法進行了停用,並為其審計和安全性問題進行致歉:


      危險的授權轉账:Li.Finance 攻擊事件始末

而後,項目方還聯系了黑客,希望能與其取得聯系並和平解決:


      危險的授權轉账:Li.Finance 攻擊事件始末

同時,最快的時間將漏洞合約修復後上线:


      危險的授權轉账:Li.Finance 攻擊事件始末

並將錢包(以Matic為例)對於之前被攻擊合約的授權取消,對新的合約進行了重新授權:


      危險的授權轉账:Li.Finance 攻擊事件始末

最後,將用戶資產進行補回:


      危險的授權轉账:Li.Finance 攻擊事件始末

同時我們關注到,其在 polygon 鏈上的合約也已實現了新的部署:


      危險的授權轉账:Li.Finance 攻擊事件始末

總結

此次攻擊的根本原因是項目方對於 swapAndStartBridgeTokensViaCBridge 合約的實現過度自由化所導致的 call 調用注入,但項目方積極的面對問題的態度和後續補救的及時性值得學習和肯定。不貴於無過,而貴與改過。

但我們仍希望能將錯誤扼殺在發生之前,應從他人的錯誤中學習並避免自己未來的錯誤,正如 Li.Finance 所說的那樣:“我們的使命是最大化用戶體驗,現在我們痛苦地了解到,為了遵循這種精神,我們的安全措施必須大幅改進。”

近期,各類合約漏洞安全事件頻發,合約審計、風控措施、應急計劃等都有必要切實落實。

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播信息之目的,不構成任何投資建議,如有侵權行為,請第一時間聯絡我們修改或刪除,多謝。

推薦文章

Hyperliquid:從史上最有價值空投到高估值警鐘

毫無疑問,Hyperliquid 是近期加密市場炙手可熱的焦點,它通過一場震撼行業的空投,不僅引發...

coincaso
13 2天前

Arthur Hayes 新文聚焦 | 全球貨幣政策的真相,比特幣接下來何去何從?

作為一名宏觀經濟預測者,我試圖基於公开數據和當前事件,作出能夠指導投資組合資產配置的預測。我喜歡“...

coincaso
19 4天前

Ouroboros DeFi:為什么 Usual Money 被低估了?

前言:Ouroboros DeFi 方法論在Ouroboros DeFi收益基金,我們的投資策略始...

coincaso
16 4天前

WEEX 唯客交易所贊助臺北區塊鏈周 支持更多全球用戶Onboard Web3

第三屆臺北區塊鏈周(Taipei Blockchain Week, TBW)於 12 月 12-1...

coincaso
17 4天前

DeFi 3.0正在到來:下一代去中心化金融的演進

DeFi 3.0正逐步成形,多個前沿項目正在引領這一波技術浪潮。$HYPE、$PENDLE、$IN...

coincaso
17 1周前

生息穩定幣協議分析:安全要點與監管難題

穩定幣在加密行業的交易、支付以及儲蓄中佔據至關重要的地位。截至目前,穩定幣市值約 2000 億美元...

coincaso
25 1周前