引子:“庖人雖不治庖,尸、祝不越樽俎而代之矣。”?--《莊子·逍遙游》
古時候,有一位杰出的領袖名叫唐堯。
他所治理的地區人們安居樂業,但是他聽聞隱士許由十分有才干,便萌生了將領導權讓給許由的想法。但是許由拒絕了,并說出了這樣一段話“鷦鷯巢于深林,不過一枝。”
至此,后人也用越俎代庖一詞來表達越權的含義。
“越俎代庖”
在智能合約的實現中存在著訪問權限,如果權限設置不合理,很容易造成智能合約被攻擊,嚴重的還會造成巨大的經濟損失。
成都鏈安-安全實驗室對于智能合約安全有著豐富的經驗和積累,但隨著區塊鏈技術越來越受重視,智能合約的數量也越來越多,隨之而來的智能合約被攻擊事件也越來越多,也讓我們感受到了“讓區塊鏈更安全”的企業使命是多么的重要,但是一己之力難于對抗所有的威脅。
接下來,我們將會把自己的安全經驗積累通過與智能合約CTF靶場ethernaut相結合,通過技術連載的方式向廣大智能合約開發者普及在開發過程中,如何實現更安全的代碼。
智能合約注冊平臺Cookbook完成200萬美元融資:金色財經報道,智能合約注冊平臺Cookbook完成 200 萬美元融資,MaC Venture Capital、Tagus Capital、Superscrypt 和 Alchemy 參投,該公司表示,新資金將用于繼續推進 Cookbook 的使命,即簡化開發人員構建 Web3 的工作并降低數百家公司的開發成本。
Cookbook表示,已服務超過 1500 名開發者,他們通過該平臺訪問了 3000 多個智能合約。該公司表示,隨著越來越多質量參差不齊的智能合約涌入網絡,其服務對開發人員的用處越來越大。[2023/5/12 14:58:20]
現在我們就來聊一聊ethernaut靶場的第一題Fallback,
代碼函數“越俎代庖”的事件。
一、權限漏洞簡介
越權漏洞是指在智能合約中,因函數可見性設置不合理或函數缺乏有效的驗證導致本不能調用某一函數的用戶通過直接或者繞過驗證的方式成功調用該函數。
Optics智能合約V1在Celo、Ethereum、Polygon正式部署:9月14日消息,開源支付網絡Celo推出的跨鏈通信互操作機制Optics智能合約V1在Celo、Ethereum、Polygon正式部署,Optics利用optimistic橋機制來實現鏈之間更便宜的通信,同時仍然保持去中心化。用戶已經可以直接與合約交互以在以上3個鏈之間發送ERC-20代幣。Optics包括一個3小時的爭議窗口來檢測任何欺詐,因此大約需要3小時 + 主鏈上的任何確認時間才能看到資金在目標鏈上結算。
此前消息,開源支付網絡Celo推出的跨鏈通信機制Optics已在一些測試網部署。[2021/9/14 23:23:41]
該漏洞可被單獨利用,也可能結合其他漏洞進行組合攻擊,利用方式簡單,漏洞影響視存在漏洞的函數而定,可能對合約造成毀滅性打擊。
二、Fallback“越俎代庖”
漏洞原理詳細分析
2.1合約中的“俎”與“庖”
如何理解合約中的“俎”與“庖”呢?先來看一段合約代碼,如下圖所示:
動態 | DEC能源鏈智能合約安全審計工作已完成,11大審計項全部通過:據DEC能源鏈團隊介紹:慢霧科技近日完成對DEC智能合約的安全審計工作,并出具審計報告。報告稱,本次包含權限控制審計、安全設計審計等11大審計大項及數項細節項,全部一次性通過審計。本次審計的合約中的代幣合約包含鎖倉部分,合約沒有使用 OpenZeppelin 的SafeMath 安全模塊,但在關鍵的地方都有校驗。合約不存在溢出、條件競爭問題,綜合評估合約無風險。[2019/7/4]
圖1
這一段合約代碼出自ethernaut靶場的第一題Fallback。針對于靶場中的問題,解題思路是通過調用回調函數function()payablepublic來觸發owner=msg.sender;,使得合約的所有者變成調用者。
題目非常的簡單,只要向此合約發起一筆交易,且滿足require的條件就可觸發fallback函數。
正常情況下,在對一個合約調用中,如果沒有其他函數與給定的函數標識符匹配,或者沒有提供附加數據,那么fallback函數會被執行。一般是作為轉入以太幣的默認操作。所以智能合約開發時一般是不需要將owner=msg.sender寫到fallback函數中的。
動態 | 智能合同審計公司Quantstamp推出新的區塊鏈安全協議:據The Innovation Enterprise 9月3日消息,Quantstamp已經發布了它的betanet協議,現在可以通過Ethereum net進行實時訪問。Quantstamp將為Ethereum用戶提供可公開驗證的智能合同審計服務。以前,用戶必須相信智能合約開發人員事先已采取必要的安全預防措施,并且無法自行驗證。Quantstamp betanet協議現在允許用戶使用QSP令牌來驗證其代碼可靠性,從而為他們提供可驗證的合同記錄,任何人都可以公開訪問該記錄。[2018/9/3]
如下圖所示:
圖2
然而,在這里本不該被用戶調用的owner=msg.sender被調用了,導致權限控制不當,產生了越權,“俎”與“庖”就這樣發生了接下來的故事。
2.2相關安全事件
2.2.1Bancor合約事件
2020年6月18日,Bancornetwork被爆出存在漏洞。
智能合約創始人Nick Szabo:比特幣是這個星球上最安全的金融網絡:智能合約創始人Nick Szabo消稱,比特幣是這個星球上最安全的金融網絡,但其中心化的外圍公司是屬于最不安全這一類的。他提到Mt.Gox曾在網絡攻擊中損失4億美元,Bitfinex曾在網絡攻擊中損失7200萬美元,美國數字貨幣交易所Cryptsy曾因攻擊損失900萬元。[2018/6/20]
漏洞產生的原因是合約中存在一個public的safeTransferFrom方法,使得攻擊者可以直接調用此方法授權給Bancornetwork合約的代幣轉出到任意賬戶。
其關于轉賬和授權的三個函數權限均為public,這使得任何用戶都能對其進行調用。本次事件涉及資金50W余美元。
詳細代碼如下圖所示:
圖3
權限為public的safeTransferFrom方法這個“奸臣”并沒有得到Bancor合約“國王”的許可,直接奪走了“國家”的“財政大權”。
幸而Bancornetwork團隊和白帽首先發現了此問題,并對資金進行了轉移。在后續也對該漏洞進行了修復,才得以避免損失。
詳細分析見
而同樣的事件也在另外一個合約中上演,接下來我們將介紹6月底的VETH合約漏洞事件。
2.2.2VETH項目事件
2020年6月30,VETH項目被爆出漏洞。本次事件中“越俎代庖”的主角則是合約中的changeExcluded函數的external修飾符。
external修飾符使得任何人都可以調用changeExcluded函數來繞過transferFrom函數內部的授權轉賬額度檢查,將合約的VETH代幣盜走。
此次事件,攻擊者利用此漏洞盜走919299個VETH后大量拋售,導致VETH代幣價值瞬間流失。
詳細見涉及到的合約代碼如下圖所示:
圖4
通過以上兩個案例,相信大家已經意識到了合約中“越俎代庖”事件的嚴重影響,那么如何在合約代碼編寫的過程中有效的區分“俎”與“庖”呢?
2.3“俎”、“庖”信息大揭秘
針對越權事件,首先需要合約開發人員了解函數可見性。
函數的可見性,一共有external、public、internal和private四種:
-External
外部函數作為合約接口的一部分,意味著我們可以從其他合約和交易中調用。一個外部函數f不能從內部調用。當收到大量數據的時候,外部函數有時候會更有效率,因為數據不會從calldata復制到內存.
-Public
public函數是合約接口的一部分,可以在內部或通過消息調用。對于public狀態變量,會自動生成一個getter函數。
-Internal
這些函數和狀態變量只能是內部訪問,不使用this調用。
-Private
private函數和狀態變量僅在當前定義它們的合約中使用,并且不能被派生合約使用。
開發人員在構造一個函數時,應當遵循這些可見性進行開發,要明確哪些函數是可以由用戶調用的“俎”,而哪些又是合約中不能任意替代的“庖”,以最小原則進行分配。
比如一個函數safeTransfer在設計時是用于轉賬操作的,用戶可以通過調用此函數,轉賬此合約發行的代幣。我們使用public和external都可以滿足需求,但就安全的角度,我們應當使用external,避免合約內對此函數進行調用,造成不可預期的風險。
如存在有一個safeTransferFrom函數,用戶可以通過授權給此合約其他代幣,將其他代幣轉移到一個指定地址的,當_token等于合約本身時,就會以合約本身的身份調用sadeTransfer函數,即而將合約內的錢轉到其他地址。
圖5
然而只是遵循函數可見性是遠遠不夠的,函數的可見性,只是區分了合約內部、繼承合約和外部這三個界限,遠遠不能滿足我們的需求。
想要達到較為完善的權限管理,我們應當引入“角色”的概念,如:管理員、普通用戶、特權用戶等。在合約中存儲這些角色的地址,通過判斷地址或標志變量來進行權限的控制。
如下圖所示:
圖6
通過修飾器對這些不同的“角色”進行管理,如使用onlyOwner修飾器,限制特定的地址才可調用此函數。對應“角色”的權限管理。使用修飾器的方式,可以更加清晰的判斷出是否存在紕漏。
三、安全總結
就鏈上現狀來看,智能合約權限管理錯誤造成的漏洞比比皆是,其中不乏很多“著名項目”,而此類漏洞造成的損失也是巨大的。
成都鏈安安全團隊依據多年合約審計和鏈上分析安全經驗給出以下幾點建議:
1、遵循權限最小化開發原則,在設計函數時應當就規劃好可見性。
2、建立角色機制,使用修飾器對各函數進行權限管理,避免紕漏。
3、上線前一定找專業機構做好代碼審計,正所謂“一人一個腦,做事沒商討;十人十個腦,辦法一大套”。
Tags:ETHERNTERBLIALETH幣Magic Internet MoneyMonster Slayer FinanceBLID幣
從成都出發,沿著G93國道,小面包載著我們一行十多個人一路西行,沒過多久,沿途的風景由平原變成了丘陵,道路也開始曲折回旋起來.
1900/1/1 0:00:00據Cryptonews7月15日報道,日本金融巨頭三菱日聯金融集團首席執行官表示,該集團將在“本財年下半年”發行其計劃已久的數字貨幣.
1900/1/1 0:00:00近日,隨著DeFi用例驟增,以太坊又要被占滿了。據歐科云鏈OKLink統計,以太坊全網未確認交易維持在14萬筆以上,并且呈持續上升的趨勢。以太坊網絡利用率目前已超過96%,創歷史新高.
1900/1/1 0:00:00摘要 央行數字貨幣研究所與滴滴出行正式達成戰略合作協議,促進數字人民幣在多元化出行場景中的平臺生態建設.
1900/1/1 0:00:00原文:小吒閑談 作者:插兜小哪吒 今天說一說穩定幣AMPL,如果你沒聽過,還不知道它,那么接下來你一定會知道它。看它像資金盤,又不像;看它像正經項目,又覺得它馬上會崩盤.
1900/1/1 0:00:00最近,幣圈真的有點涼。 雖然,DeFi爆火,很多投資人感受到了加密貨幣市場的暗流涌動,但比特幣和主流幣,幾乎橫盤了3個月,一點牛市的樣子也沒有.
1900/1/1 0:00:00