谷歌開源了一個項目可為C/C++ 庫創建安全策略
近日,谷歌開源了 Sandboxed API(沙箱式API)。該項目用於在Linux系統上運行的C/C++庫,是谷歌公司內部多年來一直在數據中心使用的工具,可以幫助開發人員免受惡意用戶的輸入和漏洞利用。
沙箱是什麼?
許多軟件項目需要處理到外部數據,在安全方面會顯得有些不足。當解析外部數據的軟件庫足夠複雜時,軟件會存在著嚴重的安全隱患,容易成為安全漏洞的受害者,從而遭遇內存損壞或是像路徑遍歷的邏輯解析問題。
一般的做法是將軟件隔離,這個過程就是“沙箱”。通過“沙箱”,開發人員可以確保在解析用戶生成內容涉及的代碼時,只訪問必要的資源(文件、網絡連接和其他操作系統資源)。最壞的情況下,當潛在的攻擊者取得軟件項目範圍內的遠程代碼執行權限時,沙盒技術可以將這些部分包含,從而保護其餘的軟件基礎結構。
沙盒技術必須具有很強的抵禦攻擊能力,從而充分保護操作系統的其餘部分。同時沙箱必須足夠易於使用,以供軟件開發人員使用。為了幫助完成這項任務,谷歌開源了Sandboxed API,一個經過實戰考驗的項目,可以為各個軟件庫創建安全策略。
Sandboxed API用於訪問沙盒庫中的各個軟件功能,也因此谷歌還公開了核心沙盒項目Sandbox2。Sandbox2現在是Sandboxed API的一部分,提供了底層的沙盒原型。它也可以單獨用於隔離任意Linux進程,可以視為更低級的API。
Sandboxed API 怎麼工作?
Sandboxed API 目前是針對用C 語言編寫的軟件庫實現的,未來可能增加更多編程語言的支持。
從高層次的角度看,Sandboxed API 將要加入沙箱的庫和其調用者分成兩個獨立的操作系統進程:主機二進製文件和沙箱。具體的工作流程是:實際的庫調用由主機端的API 對象進行編組,通過進程間的通信發送到沙箱,沙箱的RPC stub 會進行解組,並將調用轉發到原始庫。
其中,API 對象(即圖中的SAPI 對象)和RPC stub 都由項目提供,前者由接口生成器自動生成。用戶只需提供沙盒策略、允許底層庫進行的一組系統調用,以及允許訪問和使用的資源。這些準備好了之後,基於沙盒API 的庫就可以輕鬆地在其他項目中重用了。
生成的SAPI 對象的API 類似於原始庫的API,不過會有額外的代碼出現。這些代碼用來設置沙箱,以及將內存傳入和傳出沙箱。但除此之外,代碼流保持不變。
未來計劃
Sandboxed API 和Sandbox2 已經被谷歌的許多團隊使用。雖然該項目已經成熟,但除了維護之外,谷歌也做了一些未來的計劃: