出於安全考慮,ios系統的沙盒機制規定每個應用都只能訪問當前沙盒目錄下面的檔案(也有例外,比如系統通訊錄能在使用者授權的情況下被第三方應用訪問),這個規則把ios系統的封閉性展現的淋漓盡致。
一、沙盒中幾個主要的目錄
每個沙盒下面都有相似的目錄結構,如下圖所示(出自蘋果官方文件):
二、獲取主要目錄路徑的方式
1、沙盒目錄
nslog(@"%@",nshomedirectory());
輸出結果:
2、tmp
nslog(@"%@",nstemporarydirectory());
nslog(@"%@",[[nsbundle mainbundle] bundlepath]);
nsarray *paths = nssearchpathfordirectoriesindomains(nsdocumentdirectory, nsuserdomainmask, yes);
nsstring *path = [paths objectatindex:0];
nslog(@"%@",path);
該方法用於返回指定範圍內的指定名稱的目錄的路徑集合。有三個引數:
directory
nssearchpathdirectory型別的enum值,表明我們要搜尋的目錄名稱,比如這裡用nsdocumentdirectory表明我們要搜尋的是documents目錄。如果我們將其換成nscachesdirectory就表示我們搜尋的是library/caches目錄。
domainmask
nssearchpathdomainmask型別的enum值,指定搜尋範圍,這裡的nsuserdomainmask表示搜尋的範圍限制於當前應用的沙盒目錄。還可以寫成nslocaldomainmask(表示/library)、nsnetworkdomainmask(表示/network)等。
expandtilde
bool值,表示是否展開波浪線~。我們知道在ios中~的全寫形式是/user/username,該值為yes即表示寫成全寫形式,為no就表示直接寫成「~」。
iOS沙盒目錄結構解析
出於安全考慮,ios系統的沙盒機制規定每個應用都只能訪問當前沙盒目錄下面的檔案 也有例外,比如系統通訊錄能在使用者授權的情況下被第三方應用訪問 這個規則把ios系統的封閉性展現的淋漓盡致。每個沙盒下面都有相似的目錄結構,如下圖所示 出自蘋果官方文件 每個應用的沙盒目錄都是相似的,主要包含圖中所示的4...
iOS沙盒目錄結構解析
出於安全考慮,ios系統的沙盒機制規定每個應用都只能訪問當前沙盒目錄下面的檔案 也有例外,比如系統通訊錄能在使用者授權的情況下被第三方應用訪問 這個規則把ios系統的封閉性展現的淋漓盡致。每個沙盒下面都有相似的目錄結構,如下圖所示 出自蘋果官方文件 每個應用的沙盒目錄都是相似的,主要包含圖中所示的4...
複習iOS沙盒目錄結構解析
存放內容 該目錄包含了應用程式本身的資料,包括資源檔案和可執行檔案等。程式啟動以後,會根據需要從該目錄中動態載入 或資源到記憶體,這裡用到了lazy loading的思想。整個目錄是唯讀的 為了防止被篡改,應用在安裝的時候會將該目錄簽名。非越獄情況下,該目錄中內容是無法更改的 在越獄裝置上如果更改了...