Android 11對應的API為30,從這個版本起要想對外部存儲進行寫入操作的話需要比以往的操作多幾個步驟,這裡簡單歸納下,具體的原因我就不多話了,具體步驟如下以供參考
1-在AndroidManifest.xml裡這樣注冊權限:
<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下已經不起作用了,但在API29中還有作用,所以一并加上以免麻煩。
3-在代碼中申請權限,由于這些新加的權限特殊,以往的申請方式不起作用,無論怎麼申請,最後必然是授權失敗。所以正确的方式就是先判斷API的版本,如果大于等于30則用Environment.isExternalStorageManager()判斷是否有授權,這個方法會返回一個布爾值,如是false就跳到一個特殊的頁面讓用戶手動授權,跳轉方法如下:
val intent = Intent(Settings.ACTION_MANAGE_APP_ALL_FILES_ACCESS_PERMISSION)
intent.data = Uri.parse("package:" requireActivity().packageName)
startActivity(intent) //startActivityForResult(intent,0x01)
由于這個授權界面是一個Activity,所以用startActivity還是startActivityForResult都可以,具體看你怎麼利用生命周期了。
手動授權界面
4-記得用傳統方式申請下WRITE_EXTERNAL_STORAGE,以免産生不必要的麻煩。
到此,針對Android 11的外部存儲的權限申請就這樣了。最後說一下,雖然通過上述方式可以對整個外部存儲空間進行文件的讀寫操作,但Android/data目錄是個例外,此目錄下保存着所有應用的專屬空間,在Android11下已經不讓訪問了,但可以通過代碼方式直接訪問自己的那個目錄。
,更多精彩资讯请关注tft每日頭條,我们将持续为您更新最新资讯!