Android 11對應(yīng)的API為30,從這個版本起要想對外部存儲進行寫入操作的話需要比以往的操作多幾個步驟,這里簡單歸納下,具體的原因我就不多話了,具體步驟如下以供參考
1-在AndroidManifest.xml里這樣注冊權(quán)限:
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.MANAGE_EXTERNAL_STORAGE" />
比以往多一條MANAGE_EXTERNAL_STORAGE
2-在AndroidManifest.xml的application下加入android:requestLegacyExternalStorage="true"
其實這句在API30下已經(jīng)不起作用了,但在API29中還有作用,所以一并加上以免麻煩。
3-在代碼中申請權(quán)限,由于這些新加的權(quán)限特殊,以往的申請方式不起作用,無論怎么申請,最后必然是授權(quán)失敗。所以正確的方式就是先判斷API的版本,如果大于等于30則用Environment.isExternalStorageManager()判斷是否有授權(quán),這個方法會返回一個布爾值,如是false就跳到一個特殊的頁面讓用戶手動授權(quán),跳轉(zhuǎn)方法如下:
val intent = Intent(Settings.ACTION_MANAGE_APP_ALL_FILES_ACCESS_PERMISSION)
intent.data = Uri.parse("package:" + requireActivity().packageName)
startActivity(intent) //startActivityForResult(intent,0x01)
由于這個授權(quán)界面是一個Activity,所以用startActivity還是startActivityForResult都可以,具體看你怎么利用生命周期了。

4-記得用傳統(tǒng)方式申請下WRITE_EXTERNAL_STORAGE,以免產(chǎn)生不必要的麻煩。
到此,針對Android 11的外部存儲的權(quán)限申請就這樣了。最后說一下,雖然通過上述方式可以對整個外部存儲空間進行文件的讀寫操作,但Android/data目錄是個例外,此目錄下保存著所有應(yīng)用的專屬空間,在Android11下已經(jīng)不讓訪問了,但可以通過代碼方式直接訪問自己的那個目錄。
-
Android
+關(guān)注
關(guān)注
12文章
4026瀏覽量
134031 -
存儲
+關(guān)注
關(guān)注
13文章
4793瀏覽量
90077 -
API
+關(guān)注
關(guān)注
2文章
2375瀏覽量
66805
發(fā)布評論請先 登錄
鴻蒙原生應(yīng)用元服務(wù)-訪問控制(權(quán)限)開發(fā)工作流程相關(guān)
Android中數(shù)據(jù)存儲的介紹和使用
HarmonyOS開發(fā)權(quán)限申請的方法
在Android 11中OTA工具讀寫的文件夾不具有訪問權(quán)限,不能升級是為什么?
請問是否有關(guān)于Android11平臺默認開放root權(quán)限的文檔?
Android系統(tǒng)權(quán)限提升攻擊檢測技術(shù)_王聰
如何使用權(quán)限的Android進行應(yīng)用風(fēng)險評估方法的資料說明
如何使用Android的權(quán)限實現(xiàn)應(yīng)用風(fēng)險評估詳細方法說明
基于權(quán)限的Android應(yīng)用風(fēng)險評估方法
鴻蒙APP開發(fā)鴻蒙權(quán)限請求框架
外部存儲和內(nèi)部存儲的區(qū)別
Purple Pi OH Android11 ROOT方法
Purple Pi OH Android11 ROOT方法
Android 11的外部存儲權(quán)限申請流程分享
評論