比特幣交易所 比特幣交易所
Ctrl+D 比特幣交易所
ads

通縮幣頻遭閃電貸攻擊,罪魁禍首竟是獎勵分配機制?_KEN

Author:

Time:1900/1/1 0:00:00

近日,CertiK監測到兩起針對FETA以及BEVO反射機制的通縮幣項目的閃電貸攻擊事件。為幫助讀者對此類攻擊事件有更全面的了解,本文將對此類通縮幣項目的背景、攻擊過程、攻擊原理以及防范方法進行具體分析并總結,期望各位讀者能對該類型攻擊有較為深入的理解和啟發。

背景

通縮幣是一種隨著交易進行不斷有token被銷毀,發行總量因此不斷減少進而實現潛在升值的數字貨幣。

隨著2021年Safemoon項目的一炮而紅,通縮幣項目在當時幾乎橫掃主流的ERC20項目,備受矚目。

對于通縮機制本身,大部分項目都使用了Reflect這一最經典的通縮獎勵分配機制。Reflect機制即“反射”機制,可以將通縮產生的收益讓所有的持幣者根據持幣量平均分配。在該機制下,用戶手里的token有了兩種計量方式,即:“反射”前的實際token數量,和“反射”后的反射token數量。

TRX單日銷毀量達到近期平均通縮水平的3倍:據官方消息,2023年2月6日,TRX單日銷毀量達23,930,392枚,通縮18,983,561枚,達到近期平均通縮水平的3倍。截至目前,TRX總銷毀量達14,962,704,934枚,總供應量已降至91,736,499,457枚。

當前,波場TRON賬戶總數突破1.41億,交易總數突破48億,總質押量(TVL)突破113億美元,已成為當下最活躍的區塊鏈之一。隨著波場TRON網絡交易、賬戶的增加,以及DApp生態的持續擴大,TRX銷毀量多次迎來階段高峰。[2023/2/8 11:54:29]

該機制中,通縮的來源是對于token交易者的懲罰性稅收,在每次交易時對交易賬戶“反射”后的token數量進行一定比例的收稅和銷毀,從而改變了“反射”的比率,使得每個普通持幣者都可以獲得更多的“反射”前的token作為獎勵。

以太坊自合并以來供應量實現通縮超6,408枚ETH,創歷史新高:2月2日消息,據ultrasound.money數據顯示,以太坊自合并以來,流通供應量實現通縮減少6,406.08枚 ETH,通縮數量創歷史新高。[2023/2/2 11:42:30]

由此可見,Reflect是一種靜態獎勵機制,為了鼓勵長期持幣者而懲罰頻繁交易者,使得更多用戶愿意持有和參與,最終促使幣價趨于穩中有升的態勢。

有趣的是,包含Reflect機制的智能合約很多都會加入一個函數,即`deliver()`。該函數的作用是調用者以“犧牲自我”的方式,直接銷毀自己的token,從而改變“反射”機制的比率,使每一位持幣者得到獎勵。

這種犧牲自我利益為所有持幣者謀福利的做法不失為一種“慈善捐贈”,調用這個函數的人就好像“天使”一般。然而,天使的背后也有可能是魔鬼。CertiK最近監測到的兩起攻擊事件,正是利用了`deliver()`函數改變“反射”機制的比率,對通縮幣在去中心化交易所的交易對地址發起了閃電貸攻擊,盜走交易對中的大額WBNB。

加拿大企業家Kevin O'Leary支持以太坊通縮:8月10日消息,加拿大企業家、投資者及電視真人秀主持人Kevin O'Leary在名人個性化視頻信息網站Cameo上宣揚以太坊8月5日倫敦升級的好處,他認為,一旦以太坊發生鏈式合并,它注定會成為“ultrasound money”。

此前消息,EIP-1559實施之后,ETH銷毀總量達到20000枚。(Cointelegraph)[2021/8/10 1:45:49]

攻擊案例分析

2023年1月31日,CertiK監測到通縮幣項目FETA遭受到閃電貸攻擊。攻擊者通過閃電貸借到18.5個WBNB后,通過調用FETA的`deliver()`函數以及去中心化交易所中FETA-WBNB交易對合約的`skim()`函數,在歸還閃電貸借款之后仍獲利10.34個WBNB。

OKEx徐坤:隨著機構囤幣,比特幣已進入通縮狀態:OKEx首席戰略官徐坤表示,比特幣這一輪上漲是海外機構投資者入場帶動的。在徐坤看來,比特幣走向主流已經是必然的趨勢。但她同時也表示,比特幣現在整體體量還是很小,要達到和黃金同等量級的規模,還需要有10倍的增長空間,伴隨著大量以資產配置為目的的機構開始“囤幣”,比特幣實際上已經進入通縮狀態。(21世紀經濟報道)[2020/12/30 16:02:36]

無獨有偶,在前一日,CertiK還監測到另外一起類似的閃電貸攻擊事件,被攻擊對象是通縮幣項目BEVO,攻擊者通過類似的方法獲利144個WBNB。

這兩起攻擊事件看上去仿佛只需調用兩個十分普通的函數就可以攻擊成功,那么這種“魔法”究竟是怎么施展的呢?

我們不難發現,對于普通用戶地址而言,反射機制的邏輯以及`deliver()`函數的邏輯都是沒有問題的,甚至是非常高明的獎勵機制,否則通縮幣項目也不可能如此受到認可。問題恰恰在于“不那么普通”的地址——下面我們看看如果對去中心化交易所的交易對地址使用了“反射”機制究竟會發生什么。

現場 | 中國銀行首席科學家郭為民:比特幣根本不是貨幣 不存在通脹或通縮的問題:金色財經現場報道,2019年第一財經金融科技峰會12月1日在北京舉行。在主題為《區塊鏈與數字貨幣》的高峰對話環節中,中國銀行首席科學家郭為民認為,比特幣在黃賭領域非常成功,在其他領域并不成功。比特幣本身就是一個騙局,根本不是貨幣,不存在通脹通縮的問題。相對于傳統金融機構來說,不存在成本比較的問題。另外,區塊鏈技術是一個非常低效的技術。[2019/12/1]

首先,根據“反射”機制的代碼可知,在“反射”前后,用戶的token數量是通過乘以一個比率rate來相互轉化的,若我們設“反射”前的token數量為tAmount,“反射”后的token數量為rAmount,則有

其中rate系兩種計量方式的總量之比,即

把rate帶入,我們可以得到用戶的實際token數量

對于所有加入“反射”機制的地址,由于每次有交易者在交易時都會交稅并通過銷毀減少一些rTotal,根據公式,在rAmount、tTotal不變的情況下,tAmount將會增加,即實現了靜態持有時的增值。

`deliver()`函數可以直接減少rTotal,同時保持tTotal不變,此時rate將會極具下降。若此時關注該token在去中心化交易所的交易對地址pair,則pair對應的balance,即用tAmount衡量的token數量會大幅增長。

而去中心化交易所的交易對智能合約作為數字貨幣的交換池,存儲了大量該交易對的兩種token,例如BEVO-WBNB。該智能合約提供了一個函數`skim()`,可以讓用戶把合約中token的balance數值和交換池中實際存儲的token數量reserve的差值取出來,正是這個方法讓攻擊者發現了套利空間。

根據上文所述,當調用`deliver()`函數時,rTotal減少會帶動pair的balance,即用tAmount衡量的token數量的大幅增長,然而pair里面實際存儲的token數量reserve并沒有發生變化,此時,兩部分的差值全部會被攻擊者調用`skim()`全部取出來。

然而想要調用`deliver()`函數,即完成初始的“捐款”,是需要啟動資金的。對于攻擊者來說,方法總比困難多——方法即為我們平時經常聽說的閃電貸。

也就是說,攻擊者只需在一個區塊之內將錢還上,就可以借到大量的錢用`deliver()`函數操縱交易對的balance。最終,只要通過`skim()`取出來并換成WBNB的錢比借到的錢多,攻擊者就完成了一次無風險套利。

總攻擊過程如下圖所示:

攻擊防御

知道了原理,那又該怎么預防呢?

能夠帶來嚴重損失的漏洞,或許在事情發生前就進行預防,并不十分復雜。根據CertiK安全專家的分析,攻擊者要想鉆空子,需要能夠改變合約中rTotal的數量,進而操縱合約中交易對的balance。

在此,CertiK專家建議:

要么在設計合約的時候直接剔除有風險的`deliver()`函數,要么直接將交易對地址剔除Reflect機制,即在代碼中或合約部署后,調用`excludeFromReward()`將pair地址填入,使其剔除反射獎勵機制即可。此時pair的balance將無法被攻擊者通過`deliver()`函數所操縱。

寫在最后

CertiK通過兩起最近發生的通縮幣閃電貸攻擊事件,詳細講述了包含Reflect機制的通縮幣被攻擊的原理和預防方法,希望能給各位讀者有所啟示。

通縮幣作為最常見也是最經典的數字貨幣類型之一,至今仍然能被攻擊者抓住漏洞進行攻擊,主要原因也是項目方在智能合約設計時僅考慮到數字貨幣自身的智能合約邏輯,卻并未深入研究與去中心化交易所合約交互的過程,才釀成了如此的損失。

Tags:TOKETOKENTOKKENGlory TokentybtokenXOC TokenShibaken Finance

酷幣交易所
比特幣(BTC)印出“死亡十字”時值得關注的 7 種加密貨幣_比特幣

由于加密貨幣復合體勉強守住其1萬億美元的關鍵市值,因此圍繞著值得關注的單個加密貨幣的潛在軌跡存在重大問題.

1900/1/1 0:00:00
人工智能可以改變加密貨幣,但不是現在_加密貨幣

簡單來說 自2023年初以來,AI代幣的受歡迎程度和價格呈爆炸式增長。但是關于我們可以將區塊鏈與AI集成到何種程度一直存在爭論。目前的專家共識是,近期的市場抽水缺乏對技術的深刻理解.

1900/1/1 0:00:00
關于上線【幣瑪理財】并開啟首期SOL定期理財APY4.5%的公告_MAR

親愛的用戶: CoinMark平臺已上線并開啟首期“SOL定期理財APY4.5%”的活動,活動詳情如下: 理財入口:幣瑪理財 申購時間:2022年5月23日10:00—5月25日23:59Saf.

1900/1/1 0:00:00
LUNC升級 v1.0.5,會重回巔峰嗎?_ASS

由于升級v1.0.5的推出,TerraClassic(LUNC)代幣將在短期內對其價格產生積極影響。此次升級將使Binance加密貨幣交易平臺上的代幣銷毀過程得以恢復.

1900/1/1 0:00:00
交易BLUR/USDT永續合約,贏$30,000獎勵_比特幣

用戶進行鏈上充值、交易BLUR/USDT永續合約、分享收益截圖等,瓜分$30,000獎勵!活動時間:2023年2月15日10:00-2023年2月25日10:00UTC填寫表單:https://.

1900/1/1 0:00:00
揭秘Blur的前世今?:空投 發幣,驚喜在哪里?_BLUR

原文標題:《情人節特輯:Blur空投發幣,驚喜在哪里(TheFloorisAllYours,Blur)》原文作者:Eric.

1900/1/1 0:00:00
ads