穩健,是 Gate 持續增長的核心動力。
真正的成長,不是順風順水,而是在市場低迷時依然堅定前行。我們或許能預判牛熊市的大致節奏,但絕無法精準預測它們何時到來。特別是在熊市週期,才真正考驗一家交易所的實力。
Gate 今天發布了2025年第二季度的報告。作爲內部人,看到這些數據我也挺驚喜的——用戶規模突破3000萬,現貨交易量逆勢環比增長14%,成爲前十交易所中唯一實現雙位數增長的平台,並且登頂全球第二大交易所;合約交易量屢創新高,全球化戰略穩步推進。
更重要的是,穩健並不等於守成,而是在面臨嚴峻市場的同時,還能持續創造新的增長空間。
歡迎閱讀完整報告:https://www.gate.com/zh/announcements/article/46117
智能合約DoS攻擊風險與防範策略解析
智能合約中的拒絕服務攻擊
拒絕服務(DoS)攻擊可能導致智能合約在一段時間內甚至永久無法正常使用。主要原因包括:
合約邏輯存在缺陷。如某些public函數實現沒考慮計算復雜度,可能超出Gas限制導致交易失敗。
跨合約調用場景中,合約執行依賴外部合約狀態。外部合約執行不可靠可能阻塞本合約運行,如資金被鎖定無法充提。
人爲因素,如合約所有者丟失私鑰,導致關鍵系統狀態無法更新。
下面結合具體例子分析DoS攻擊漏洞。
1. 循環遍歷可被外部修改的大數據結構
以下是一個用於給註冊用戶"分紅"的簡單合約:
合約狀態包含註冊用戶列表和帳戶餘額映射。用戶可通過register_account()註冊並初始化。
管理者通過distribute_token()爲用戶分紅,遍歷registered數組向每個用戶轉帳指定數量代幣。
問題在於registered大小無限制且可被惡意操控,導致遍歷時Gas消耗過高超出限制。
推薦解決方案:
2. 跨合約狀態依賴導致阻塞
考慮一個"競價"合約場景:
問題在於退款依賴外部合約狀態。如果之前最高出價者帳戶已注銷,退款將失敗,導致無法更新最高價,整個競拍過程阻塞。
解決方法: 考慮外部調用可能失敗,實現合理的錯誤處理。如將無法退回的資金暫存,後續允許用戶單獨提取。
3. 管理員私鑰丟失
部分關鍵函數(如暫停/重啓交易)僅允許管理員調用。管理員私鑰丟失將導致這些功能無法使用,合約可能長期無法正常運行。
解決方法: 採用多籤名機制替代單一管理員,實現去中心化治理,避免單點故障。