買以太坊 買以太坊
Ctrl+D 買以太坊
ads
首頁 > 幣贏 > Info

WOW:波場 DApp 再遭手!游戲 TronWow 變提款機,Peckshield 深度講解黑客手法_888Tron

Author:

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

據區塊鏈安全公司PeckShield安全盾風控平臺DAppShield監測消息,4月10日23點02分,黑客向波場競猜類游戲TronWow發起攻擊1,203次,共計獲利2,167,377個TRX。PeckShield安全人員當即展開分析發現,黑客每投注20TRX,即可獲得1,940個TRX作為回報,回報率高達97倍。最終,通過此次攻擊,黑客共計投注23,004個TRX,獲利2,167,377個TRX。

此后,PeckShield安全人員進一步深入分析發現,TronWow合約在檢查下注范圍時存在缺陷,允許用戶在非頁面下注時構造惡意輸入,從而實現穩贏的游戲結果。

原文標題:《TronWow遭攻擊詳解:黑客能穩贏且回報率高達97倍》

攻擊細節:

TronWow是一個典型的dice類游戲。玩家通過選定下注數字和押大押小來進行一輪游戲。

波場TRON用戶數突破5900萬:2021年10月28日,根據TRONSCAN區塊鏈瀏覽器最新數據顯示,波場TRON賬戶總數達到59,011,166,正式突破5900萬。波場TRON各項數據穩中前進,波場TRON生態逐漸強大的同時,也將迎來更多交易量。[2021/10/28 21:04:53]

如下圖所示,當用戶在TronWow游戲頁面中參與游戲,無論選擇Under模式或Over模式,都被限制了下注數字的范圍和勝率。其中

Under模式可下注數字為,Over模式可下注數字為,游戲隨機生成數字范圍為,Under和Over兩種模式的勝率均為,獎勵倍數為。

PeckShield安全人員在深入逆向分析TronWow合約時發現,TronWow合約在檢查下注范圍時存在缺陷,允許用戶在非頁面下注時構造惡意輸入。換而言之,一旦用戶避開游戲頁面,直接調用游戲合約的下注函數,即可設法繞過合約中的下注范圍檢查條件,實現100%勝率以及最高回報倍數。

Bibox已經支持基于波場鏈發行的BTC(TRC20-BTC)的充值及提現:據官方消息,Bibox已經支持基于波場鏈發行的BTC(TRC20-BTC)的充值及提現。據悉,TRC20-BTC 由 JUST 基金會發行,是繼發行量突破 40 億美元的 TRC20-USDT 之后,波場(TRON)網絡資產的又一力作。任何 BTC 持有者都可以參與 TRC20-BTC 的發行,目前 P 網(Poloniex)已支持 TRC20-BTC 兌換。TRC20-BTC合約已由第三方代碼審計公司慢霧科技進行審計。[2020/10/29]

下面以正常下注交易和惡意下注交易對該合約漏洞進行說明。

在TronWow合約代碼中,函數placeBet(uint24_betMask,uint256_commit,bytes32_r,bytes32_s)為下注函數,參數uint24_betMask為玩家的下注信息。

孫宇晨:波場生態TRX正式進軍區塊鏈預言機市場:據最新消息顯示,波場TRON創始人兼BitTorrent CEO孫宇晨剛剛公布:“波場三大決策更新:波場版Uniswap JUSTswap 8月17日上線,USDJ JST質押挖礦8月31日上線,與此同時,波場生態TRX正式進軍區塊鏈預言機市場!”據悉,波場TRON大航海時代4.0發布會剛剛圓滿結束,發布會全程直播持續8小時,42位行業領軍人物參與了線上發布會,在全球達到超1000萬的熱度,全球超100萬人同時在線觀看視頻直播。[2020/7/21]

其中正常下注交易調用placeBet函數時輸入如下:

這是一個選擇了Under模式且下注數字為95的正常交易,換而言之,當游戲生成的隨機數小于等于95時玩家獲勝。

在此交易中,參數_betMask的值24321轉換成十六進制為0x005F01,我們將其分拆為三個字節,分別如下:

以波場TRON網絡為基礎發行的穩定幣借貸平臺JUST已被DApp Total收錄:據最新消息顯示,以波場TRON網絡為基礎發行的穩定幣借貸平臺JUST已正式被DApp Total收錄,用戶可以在DApp Total平臺上查看JUST項目的用戶數、交易額、排名等基本數據。JUST旨在建立一個公平、去中心化的金融系統,為世界各地的用戶提供穩定的貨幣借貸和治理機制。此外,JUST(JST)作為Poloniex(P網)LaunchBase首發項目,將于5月5日正式上線。[2020/4/22]

其中:

0x00為十進制0;0x5F為十進制95;0x01為十進制1.其中第一部分0x00表示若當該輪游戲產生的隨機數計算結果處于之間,則玩家獲勝;相反,前兩位不為0x00時表示若該輪游戲產生的隨機數計算結果處于之外,則玩家獲勝。

在逆向過程中,我們將下注函數的部分匯編指令還原成偽代碼,如下圖所示:

閱讀上述下注函數偽代碼可以發現,合約只對玩家下注信息中的勝率百分數進行了檢查,要求其小于等于95,卻未對下注數字做數值限制。故玩家可通過構造下注數字來繞過該檢查。

下圖為攻擊者發起的諸多攻擊交易之一:

其中_betMask參數被構造為130971,十六進制為0x01FF9B。其中前兩位0x01表示若該輪游戲產生的隨機數計算結果處于之外,則玩家獲勝。而0x9B、0xFF對應的十進制分別為155、255,則根據合約撰寫的勝率百分比計算規則,winRate=100-(0xFF-0x9B)1,即等于1,從而成功繞過下注范圍檢查函數,并將本次交易的獎勵倍數設置為97。需要特別強調的是,在頁面下注中,獎勵倍數最高僅為48.5倍。

接著,我們將開獎函數settleBet(uint256_reveal,bytes32_txHash)的判斷游戲輸贏部分匯編指令還原成偽代碼:

其中rollResult為本輪游戲的隨機數計算結果,取值范圍為。而在攻擊者設置的惡意參數中,rollResult必然處于區間之外,滿足贏得本輪游戲的條件,從而確保了攻擊者游戲結果穩贏。

總結:

對于TronWow合約被攻擊事件,PeckShield安全人員分析發現:TronWow合約在檢查下注范圍時存在缺陷,允許用戶在非頁面下注時構造惡意輸入,實現100%勝率。需要注意的是,該漏洞已在TronWow上線的新版本合約中被修復,游戲方增添了對下注范圍的約束檢查。

在此,PeckShield安全人員提醒廣大項目方及交易所應當重視區塊鏈世界中的任何安全問題,確保項目方及用戶的資產安全可靠。安全無小事,采取不公布源代碼來抵御黑客攻擊的行為,在黑客面前形同虛設。DApp開發者應杜絕僥幸心理,在合約上線前做好必要的安全措施和已知攻擊特征檢查,必要時可聯系第三方安全公司進行漏洞排查,避免造成不必要的數字資產損失。

來源鏈接:mp.weixin.qq.com

本文來源于非小號媒體平臺:

PeckShield

現已在非小號資訊平臺發布1篇作品,

非小號開放平臺歡迎幣圈作者入駐

入駐指南:

/apply_guide/

本文網址:

/news/3627185.html

波場游戲鏈游TRX

免責聲明:

1.資訊內容不構成投資建議,投資者應獨立決策并自行承擔風險

2.本文版權歸屬原作所有,僅代表作者本人觀點,不代表非小號的觀點或立場

上一篇:

因高端勒索軟件感染增加,Q1加密貨幣勒索金額幾為上季度一倍

下一篇:

PeckShield深入代碼層面分析,黑客究竟如何盜走1.7億BTT?

Tags:tronTRORONWOWSHIBA TRONFrontrow888TronWOWPI

幣贏
BTC:火星一線 | 比特幣回調,幣市蒸發140億美元,后市如何?_數字資產

?? 火星財經APP一線報道,橫盤多日的比特幣在今日大幅回調,目前跌破7600美元報于7540美元,24小時下跌4.04%.

1900/1/1 0:00:00
ELD:競猜類游戲 Fastwin 遭黑客攻擊背后:Block.one 官方悄然做了重大更新_Shiba Fame

12月05日,新上線的又一款EOS競猜類游戲Fastwin遭到黑客攻擊,區塊鏈安全公司PeckShield態勢感知平臺捕捉到了該攻擊行為并率先進行了安全播報披露.

1900/1/1 0:00:00
以太坊:DAO終極之問:去中心化組織歸誰所有?_ENT

社會層與自治層之間的共生關系是比特幣的核心所在。通過DAO,任何大規模的、開放性組織或者運動將能夠獲取同樣強有力的動能.

1900/1/1 0:00:00
BRI:Bringing Ampleforth to Tokinex_Ethereum Yield

FollowingthelaunchofournewIEOplatform,Tokinex,wecannowrevealthefirsttokensalewillbeAmpleforth(AMP.

1900/1/1 0:00:00
區塊鏈:三星準備將加密資產整合到Samsung Pay中_SAMINU

CCN援引韓國主流媒體商BusinessKorea的消息稱,三星電子正準備將加密資產整合到SamsungPay中.

1900/1/1 0:00:00
比特幣:摩根溪CEO:未來十年比特幣的表現將跑贏標普500投資基金_EVE

5月22日,摩根溪資本公司首席執行官MarkYusko在接受CNBC采訪時表示,比特幣應該出現在每個投資者的投資組合中。Yusko認為在未來十年,比特幣的投資表現將遠遠好于標普500投資基金.

1900/1/1 0:00:00
ads