如今,隨著人們對DeFi的興趣日益濃厚,DEX風靡一時。它們解決了常見的CEX問題,那我們也會問,DEX夠安全嗎?
在上一篇說明了代幣本身的安全問題后|DEFI安全問題之基礎篇),現在來聊聊DEX在兌換代幣時可能產生的安全問題。目前DEX主要面臨的安全問題大致可分成兩類:
DEX項目本身存在的安全問題。
作為第三方協議,與其他DEFI項目交互時產生的安全問題。
本文將對第一類安全問題進行介紹。
Uniswap的重入漏洞的主要表現形式為:攻擊者在一筆兌換交易中利用Uniswap未及時更新價格前發起二次兌換,由于此時Uniswap未更新價格,使得二次兌換可兌出的代幣數量比正常兌換的多。此外,在Uniswap的重入攻擊中,攻擊者利用單筆交易可能只能獲得微小的收益,因此攻擊者往往傾向于使用閃電貸或者循環套利擴大戰果。
MetaMask新版本支持發送ERC-721代幣:4月5日消息,MetaMask宣布在最新版本的擴展中,只要啟用自動NFT檢測,所有ERC-721和1155代幣都會出現。通過此更新,用戶可以發送ERC-721代幣,將很快添加發送ERC-1155代幣的功能。[2023/4/5 13:44:47]
以imBTC攻擊事件為例,該事件是由于UniswapV1在調用ERC777系列代幣時,未充分考慮合約回調的情況。
具體表現為:攻擊者使用imBTC代幣兌換ETH時,合約先通過self.getInputPrice函數計算正確的ETH數額并將ETH發送到目標地址,然后調用self.token.transferFrom函數時,會調用imBTC合約的_callTokensToSend函數,而_callTokensToSend函數會調用用戶指定存儲imBTC代幣的合約。因此,如果攻擊者部署存儲合約,并改寫其中TokensToSend函數,那么當兌換代幣時,pair(兩種代幣組成的交易對)合約調用攻擊者部署的存儲合約,就可以回調pair進行二次兌換,而二次兌換時pair合約賬本還未更新,使得計算的ETH數額比正常兌換要多,以此來獲利。
LSD協議StaFi將其質押衍生產品的傭金費用從19%降至10%:金色財經報道,流動性質押衍生品協議StaFi已將其質押衍生產品的傭金費用從19%降至10%,以提高產品使用率。其中10%的傭金中,5%的費用將分配給驗證者,另外5%將分配給StaFi DAO Treasury。剩余90%的以太坊獎勵的分配將通過評估驗證者資金投入與用戶資金投入的比率來確定。[2023/3/2 12:38:07]
且正常第二次可兌換的ETH數量為:
但重入后第二次可兌換的ETH數量為:
由此可知,在重入后第二次兌換中只有ETH的儲備量減少,而imBTC儲備量未增加。這樣在分母不增加的情況下,導致了等量的imBTC可以兌換更多的ETH。
針對此類安全問題,成都鏈安建議:
ENS域名tiffany.eth以29ETH的價格出售:金色財經消息,據OpenSea信息顯示,ENS域名tiffany.eth以29ETH(約5萬美元)的價格出售。
夜間報道,美國珠寶品牌蒂芙尼推出限量版CryptoPunk定制吊墜,此前3月蒂芙尼進軍NFT領域,以115ETH購買Rocket Factory的OkapiNFT。[2022/8/1 2:50:31]
當合約涉及到資產轉移時,使用“檢查-生效-交互”模式來處理邏輯,對關鍵的業務操作可以使用OpenZeppelin官方的ReentrancyGuard進行修飾。
圖8合約進行k值校驗的Swap函數
該事件的具體攻擊步驟如下:
1.在準備階段攻擊者部署了AAA代幣合約,并使用閃電貸借來1000WBNB,兌換65140個項目方的IF代幣。
以太坊網絡當前已銷毀246.41萬枚ETH:金色財經報道,據Ultrasound數據顯示,截止目前,以太坊網絡總共銷毀2,464,154.80枚ETH。其中,OpenSea銷毀230048.81枚ETH,ETHtransfers銷毀228158.26枚ETH,UniswapV2銷毀133831.15枚。注:自以太坊倫敦升級引入EIP-1559后,以太坊網絡會根據交易需求和區塊大小動態調整每筆交易的BaseFee,而這部分的費用將直接燃燒銷毀。[2022/6/18 4:37:23]
2.使用其中一半的IF代幣(32570個)與攻擊者自己部署的AAA代幣構建IF-AAA交易池。
3.執行AAA-IF-BUSD路徑的代幣兌換,且當Router合約調用AAA代幣合約的transferFrom函數時會執行攻擊者的惡意代碼,重入至IF-BUSD的pair合約,并將另一半IF代幣正常兌換出221897個BUSD。
4.回歸到AAA-IF-BUSD路徑的兌換,將之前計算的amounts值傳入_Swap函數中執行這筆兌換,用一半的IF又兌換了2521897個BUSBD。
5.歸還閃電貸,完成攻擊。
Part.3
-DecentralizedExchange
通縮代幣未設置pair為分紅例外
通縮代幣在交易時會產生額外的分紅與手續費。如果交易合約中包含了此類代幣,且沒有進行特殊處理,那么,就可能導致交易對合約記錄的代幣儲量與實際的代幣可用余額不一致。
以XSquid事件為例,XSquid是一種通縮代幣,未將其與WHT代幣組成的pair合約地址添加獎勵例外列表,造成了pair合約除了正常代幣兌換和流動性存儲外,還存有多余的XSquid分紅獎勵代幣。因此,攻擊者就可以調用Swap函數將pair合約多余的XSquid代幣轉換為WHT提取,或者通過skim函數將多余的XSquid代幣直接提取。
PART.1
詐騙交易池
這類問題主要是指項目方在自己發行的代幣里留有后門,創建與主流代幣的交易池,誘使投資者使用手里存在價值的代幣買入項目方代幣,并且不斷拉盤對投資者進行投資欺騙。
以下面的TRTC項目方為例,項目方創建了ETH-TRTC的交易池。但是在TRTC的代幣合約對transferFrom函數做了相關限制,要求代幣的轉出方為owner(管理員)或者為Uniswap。因此對于投資者,僅可以通過Uniswap買入TRTC代幣,而不能賣出TRTC代幣。最后由項目方把投資者投入的ETH提走跑路,給投資者帶來了巨大的損失。
圖15TRTC合約的transferFrom函數
PART.2
項目方RugPull
RugPull是指項目方卷走投資者資金跑路的行為,目前已成為DeFi生態系統的最大騙局類型,項目方刻意制造代幣價格暴漲的假象、許諾為提供流動性的投資者提供高回報等方式來大量聚集資金,一旦時機成熟就移除池子里的流動性或將代幣卷走。這樣的例子在DeFi屢見不鮮,AnubisDAO、MeerkatFinance、TurtleDEX、Squidtoken魷魚幣等都是在卷款跑路之后,注銷網站和社交媒體銷聲匿跡,導致投資者承擔了巨大的損失。
寫在最后
成都鏈安建議項目方使用鎖倉和多重簽名來控制代幣流動性,避免出現砸盤跑路的情況。投資者不要被天上掉餡餅的事情沖昏頭腦,防范虛假宣傳。
Tags:ETHSWAPTRAUNIether幣對人民幣匯率ZonoSwap FinanceNFTradeuni幣現在怎么了
原文作者:WilliamM.Peaster原文來源:Bankless 原文編譯:DeFi之道 管理一個DeFi投資組合是一項積極的工作.
1900/1/1 0:00:00據TheBlock消息,3月9日,美國司法部指控DwayneGolden、GregoryAggesen和MarquisDemackingEgerton在經營名為EmpowerCoin、ECoin.
1900/1/1 0:00:00親愛的大幣網(Dcoin)用戶:大幣網(Dcoin)已完成對永續合約系統功能的升級維護,現已恢復正常交易.
1900/1/1 0:00:00公告編號2022030601各位關心ZBG的投資者們和項目方:ZBG將於HKT2022年3月6日上線SOS項目,並開放SOS/USDT交易對,具體時間如下,請投資人和項目方提前做好交易準備.
1900/1/1 0:00:00作者:念青,鏈捕手 近日,加密風投機構ElectricCapital為兩只新加密基金共籌集10億美元,其中4億美元的基金投資于股權和代幣,6億美元的基金僅投資于代幣和穩定幣.
1900/1/1 0:00:00親愛的用戶:“幣安第一期月享福利活動”、“攜手好友加入幣安合約”活動已結束;卡券獎勵已分發完成,請在我的-卡券中心查看並領取,卡券自發放當日起14天內有效.
1900/1/1 0:00:00