Android開源手機(jī)操作系統(tǒng)可以讓開發(fā)人員在模擬器中進(jìn)行相應(yīng)的操作以使系統(tǒng)滿足用戶的各種需求。在這里我們可以通過對Android讀寫文件的相關(guān)操作來體驗(yàn)一下這款操作系統(tǒng)的編寫方式。
眾所周知Android有一套自己的安全模型, 具體可參見Android開發(fā)文檔。當(dāng)應(yīng)用程序(.apk)在安裝時(shí)就會(huì)分配一個(gè)userid,當(dāng)該應(yīng)用要去訪問其他資源比如文件的時(shí)候,就需要userid匹配。默認(rèn)情況下 ,任何應(yīng)用創(chuàng)建的文件,數(shù)據(jù)庫, sharedpreferences都應(yīng)該是私有的(位于/data/data/your_project/files/),其余程序無法訪問。除非在創(chuàng)建時(shí)指明是MODE_WORLD_READABLE 或者 MODE_WORLD_WRITEABLE,只要這樣其余程序才能正確訪問。 因?yàn)橛羞@種Android讀寫文件的方法在安全上有所保障,進(jìn)程打開文件時(shí)Android要求檢查進(jìn)程的user id。所以不能直接用java的api來打開,因?yàn)閖ava的io函數(shù)沒有提這個(gè)機(jī)制 。 無法用java的api直接打開程序私有的數(shù)據(jù) ,默認(rèn)路徑為/data/data/your_project/files/
這里特別強(qiáng)調(diào)私有數(shù)據(jù)!言外之意是如果某個(gè)文件或者數(shù)據(jù)不是程序私有的,既訪問它時(shí)無須經(jīng)過Android的權(quán)限檢查,那么還是可以用java的io api來直接訪問的。所謂的非私有數(shù)據(jù)是只放在sdcard上的文件或者數(shù)據(jù), 可以用java的io api來直接打開sdcard上文件。
如果要打開程序自己私有的文件和數(shù)據(jù),那必須使用Activity提供openFileOutput和openFileInput方法。 創(chuàng)建程序私有的文件,由于權(quán)限方面的要求,必須使用activity提供的Android讀寫文件方法
讀取程序私有的文件,由于權(quán)限方面的要求,必須使用activity提供的方法
Android讀寫文件的相關(guān)操作就為大家介紹到這里。 |
|