【Chromium中文文檔】沙箱FAQ

轉載請注明出處:
https://ahangchen.gitbooks.io/chromium_doc_zh/content/zh/General_Architecture/Sandbox_FAQ.html

全書地址
Chromium中文文檔 for https://www.chromium.org/developers/design-documents
持續更新ing,歡迎star
gitbook地址:https://ahangchen.gitbooks.io/chromium_doc_zh/content/zh//
github地址: https://github.com/ahangchen/Chromium_doc_zh

什么是沙箱?

沙箱是一個允許沙箱進程創建的C++庫,沙箱進程是一種運行在非常限制性的環境中的進程。沙箱進程可以唯一自由使用的資源是CPU周期和內存。例如,沙箱進程不能寫磁盤或者顯示他們自己的窗口。它們真正能做的事情由一種明確的策略鎖控制。Chromium渲染器都是沙箱化進程。

沙箱可以保護什么,不能保護什么?

沙箱限制了運行在沙箱中的代碼的bug的危害。這些bug不能在用戶的賬號中安裝持久性的惡意軟件(因為寫文件系統被禁止),這些bug也不能讀取或者從用戶的設備中盜取任何文件。

(在Chromium中,渲染器進程是沙箱化的,它們處于這種保護中。Chromium插件還沒有運行在沙箱中,因為許多插件的設計基于這樣一個假設:它們對本地系統有著完全的訪問權限。另外也要注意,Chromium渲染器進程與系統相隔離,但還未與網絡相隔離。所以,基于域名的數據隔離還未提供)。

沙箱不能為系統組件(比如系統內核正在運行的組件)中的bug提供任何保護。

沙箱像JVM?

恩,有點像...除了你必須為Java沙箱的優點重寫代碼以使用Java。在我們的沙箱中,你可以向你現有的C/C++應用程序添加沙箱。由于代碼并非執行于虛擬機中,你可以得到原生的速度,以及對Windows API的直接訪問。

我需要安裝驅動或者內核模塊嗎?用戶需要有管理員身份嗎?

不用。沙箱是一個純用戶模式庫,任何用戶可以運行沙箱化進程。

如果沒有虛擬機,你該怎樣用C++實現沙箱?

我們為Windows安全模型劃分等級。在Windows里,沒有進行系統調用的話,代碼不能執行任何形式的I/O(無論是磁盤,鍵盤,還是顯示器)。在大多數系統調用里,Windows執行一些安全檢查。沙箱會設置好環境,這樣你不愿沙箱化進程執行的動作就會因安全檢查而失敗。在Chromium中,沙箱就是這樣,因此所有訪問檢查都會失敗。

所以一個沙箱化進程(比如渲染器)是如何完成任務的?

某些交流通道會顯式暴露給沙箱化進程;這些進程可以從這些通道進行讀寫。優先級更高的進程可以使用這些通道代表沙箱化進程執行一些動作。在Chromium中,優先級更高的進程通常是指瀏覽器進程。

Vista沒有類似的功能嗎?

有的,它被成為信用等級(ILs)。沙箱檢測Vista并使用信用等級。主要的不同在于沙箱在Windows XP下良好運行。我們知道的唯一使用信用等級的程序是IE7。換言之,沙箱庫會幫你完成對新的Vista安全特性進行分級。

這看起來很干凈。我可以在自己的程序里使用沙箱嗎?

可以。沙箱對Chromium瀏覽器沒有任何重度依賴,它就是設計用于面向Internet的應用程序。主要的障礙在于你要把你的程序分成至少兩個交互進程。一個進程具有比較高的優先級,執行I/O,與用戶進行交互;另一個進程基本上沒有什么優先權力,并執行不受信任的數據處理。

需要做很多工作嗎?

可能需要。但這是值得的,如果你的程序需要處理任意的不受信任的數據時更是如此。你的代碼中可能有的任何緩沖溢出或者格式解碼缺陷不會自動導致惡意代碼對整臺計算機造成危害。沙箱不是一個安全銀彈,但對于那些惡意使用來說,沙箱是一道強大的最后屏障。

我需要了解什么陷阱嗎?

你首先需要記住,你只需要將你完全可控的代碼或者完全理解的代碼沙箱化。沙箱化第三方代碼可能非常困難。例如,你可能不知道第三方代碼需要創建臨時文件或者彈出警告對話框;除非你顯式允許,這些操作不會成功執行。更進一步,第三方組件可以用你預料之外的新形式更新最終用戶的設備。

COM, Winsock, 或DirectX在這里又如何? — 我可以使用它們嗎?

在絕大多數情況下,不可以。我們不推薦在鎖定前使用它們(但也只能在鎖定前使用它們)。一旦一個沙箱化進程被鎖定,使用Winsock,COM,或者DirectX不是會產生故障就是會徹底失敗。

在鎖定前是什么意思?沙箱化進程不是從一開始就鎖定了的嗎?

不是,沙箱化進程并非從一開始就是處于保護之中。沙箱在進程調用LowerToken()后才開始生效。這允許進程啟動時有一段時間沙箱化進程可以自由地管理關鍵資源,加載庫,或者讀取配置文件。進程需要在它開始與不受信任的數據交互前盡快調用LowerToken()。

注意:如果你的進程被惡意軟件感染了,任何在調用LowerToken()后的仍然開放的操作系統句柄會被惡意軟件濫用。所以我們不鼓勵調用COM或者其他重量級API,它們會為了將來的調用效率遺留一些開放的句柄。

所以你可以調用什么API?

并沒有安全API的權威列表。通常,你應該結構化你的代碼,這樣沙箱化代碼可以從管道或共享內存讀寫或者用其他方式操作數據。在Chromium中,整個WebKit代碼都是用這種方式運行的,輸出大部分是網頁渲染后的位圖。你可以將Chromium作為你自己的基于內存或基于管道的IPC的靈感來源。

惡意軟件不可以感染管道或共享內存另一端的處理嗎?

是的,如果另一端有bug的話,它可以。關鍵在于,編寫和分析一個正確的IPC機制比編寫一個web瀏覽器引擎要簡單得多。所以我們將IPC代碼做得盡可能簡單,并且交由另一端去review。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,517評論 6 539
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,087評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,521評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,493評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,207評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,603評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,624評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,813評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,364評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,110評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,305評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,874評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,532評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,953評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,209評論 1 291
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,033評論 3 396
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,268評論 2 375

推薦閱讀更多精彩內容