💙 Gate廣場 #Gate品牌蓝创作挑战# 💙
用Gate品牌藍,描繪你的無限可能!
📅 活動時間
2025年8月11日 — 8月20日
🎯 活動玩法
1. 在 Gate廣場 發布原創內容(圖片 / 視頻 / 手繪 / 數字創作等),需包含 Gate品牌藍 或 Gate Logo 元素。
2. 帖子標題或正文必須包含標籤: #Gate品牌蓝创作挑战# 。
3. 內容中需附上一句對Gate的祝福或寄語(例如:“祝Gate交易所越辦越好,藍色永恆!”)。
4. 內容需爲原創且符合社區規範,禁止抄襲或搬運。
🎁 獎勵設置
一等獎(1名):Gate × Redbull 聯名賽車拼裝套裝
二等獎(3名):Gate品牌衛衣
三等獎(5名):Gate品牌足球
備注:若無法郵寄,將統一替換爲合約體驗券:一等獎 $200、二等獎 $100、三等獎 $50。
🏆 評選規則
官方將綜合以下維度評分:
創意表現(40%):主題契合度、創意獨特性
內容質量(30%):畫面精美度、敘述完整性
社區互動度(30%):點讚、評論及轉發等數據
Chrome v8漏洞利用新方法:泄露Uninitialized Oddball實現沙箱逃逸
通過泄露Sentinel Value繞過Chrome v8 HardenProtect
前言
Sentinel value是算法中的一個特殊值,通常在循環或遞歸算法中作爲終止條件存在。Chrome源碼中有很多Sentinel value。之前有研究介紹了如何通過泄露TheHole對象實現沙箱內任意代碼執行。谷歌團隊隨後迅速更新了相關修復。
除了TheHole對象外,v8中還有很多其他不應泄漏到JS中的原生對象。本文將討論Uninitialized Oddball對象,該方法目前仍可用於最新版V8。值得注意的是,這種方法具有一定的通用性,曾在多個漏洞中出現。
V8中的Sentinel Value
v8的大部分原生對象定義在v8/src/roots/roots.h文件中,這些對象在內存中依次相鄰排布。一旦將不應泄露的原生對象泄露到Javascript中,即可實現沙箱內任意代碼執行。
爲驗證該方法,我們可以通過修改v8的native函數,將Uninitialized Oddball泄漏到JavaScript中。具體可以修改%TheHole()函數中相對isolate的偏移。
繞過HardenType
利用Uninitialized Oddball可以實現相對任意讀寫。關鍵在於優化後的JavaScript read函數中,只檢查了obj的prop屬性是否正確,但沒有檢查以obj.prop爲key的Value,而是直接按JavaScript語義計算偏移,求取數組的數值。這導致在計算時造成類型混淆,實現任意讀。
由於Uninitialized Oddball在v8內存中排序靠前且更原始,相比TheHole對象更易於僞造,是TheHole緩解繞過修復後的首選方法。
建議修復方案是在優化後的函數返回數組元素時,添加對數組map的檢查,避免直接計算偏移返回數值。
PatchGap風險提示
除了關注歷史漏洞,還要注意廠商在基礎組件中悄悄修復的漏洞。目前Skype仍未修復該漏洞。x86和x64下利用方式略有不同,但都可實現任意讀寫。
這次PatchGap不僅涉及Issue1352549,新方法的公開也大大降低了類似漏洞的利用難度。黑客幾乎不需研究即可完成以往任何泄露Uninitialized Oddball漏洞的完整利用。
總結
v8中還有很多其他Sentinel value,可能存在類似問題。這給我們一些啓示:
其他Uninitialized Oddball泄露是否也易於實現v8 RCE。
此類問題是否應被正式視爲安全問題仍存在爭議。
fuzz測試時或許應考慮將各種Sentinel value作爲變量加入。
無論如何,這類問題都會大大縮短黑客的完整利用週期。我們應對此保持警惕。