Android(API 29)10 發(fā)布至今已經(jīng)有不少設(shè)備完成升級(jí),如:***小米9、Redmi K20pro、華為 P30pro/Mate30pro 、榮耀 v30/v20、Oppo Reno、ONnePlus 7T、谷歌 Pixel ***等都已經(jīng)升級(jí)到 Android 10 的支持,不少應(yīng)用市場(chǎng)也要求應(yīng)用需要針對(duì) Android 10 進(jìn)行適配,其中最大的變更之一就是 scoped storage。
在針對(duì)目前 小米、華為、Pixel 的幾臺(tái) Android 10 手機(jī)做了測(cè)試,在不設(shè)置 requestLegacyExternalStorage
的前提下得到結(jié)論(官方還沒完全開啟限制的前提):
- 1、targetSDK 用 28 編譯的在 Android 10 上還是可以讀取到全部文件, 之后覆蓋安裝一個(gè)使用 targetSDK 29 的,還能繼續(xù)可以訪問全路徑。
- 2、卸載后直接用 targetSDK 29 編譯的會(huì)讀取不到。
而官方明確表示:
明年(2020),主要平臺(tái)版本將要求所有應(yīng)用都使用分區(qū)存儲(chǔ),無論應(yīng)用的目標(biāo) SDK 級(jí)別是多少。因此,您應(yīng)該提前確保您的應(yīng)用能夠使用分區(qū)存儲(chǔ)。為此,請(qǐng)確保針對(duì)搭載 Android 10(API 級(jí)別 29)及更高版本的設(shè)備啟用了該行為。
所以不管是使用 requestLegacyExternalStorage
還是降低 targetSDK
都無法在接下來2020 年的 Android(API 29)10 新版更新中被豁免。
雖然作為 Android 開發(fā)會(huì)因?yàn)闊o法對(duì)用戶存儲(chǔ)目錄“為所欲為”而頭痛,但是作為用戶卻是感覺欣喜的。
因?yàn)殚L(zhǎng)期以來 Android 用戶的本地存儲(chǔ)目錄都十分雜亂,開發(fā)者只要申請(qǐng)一次權(quán)限就可以“為所欲為”地創(chuàng)建和讀取本地存儲(chǔ),雖然谷歌在 Android 4.4(API 19))引入了存 SAF(Storage Access Framework) , 但是開發(fā)者大部分時(shí)候都選擇無視。
我甚至想要一個(gè)系統(tǒng)標(biāo)志出這個(gè)文件是誰創(chuàng)建的 API ,因?yàn)樽罱龅竭@個(gè)問題卻沒有頭緒: 為什么相冊(cè)里總是多出一張空白圖片,刪了后不久又重現(xiàn)?
官方解讀
為了讓用戶更好地管理自己的文件并減少混亂,Android 10(API 29)開始應(yīng)用在默認(rèn)情況下會(huì)被要求使用 scoped storage(即分區(qū)存儲(chǔ)),也就是說應(yīng)用只能看到自己專有的目錄(Context.getExternalFilesDir()
)以及特定類型的媒體文件。
注意這個(gè)是強(qiáng)制性的,但是會(huì)有緩沖期,官方明確額表示,除非你的應(yīng)用真的有強(qiáng)烈需要訪問專有目錄以及
MediaStore
之外的文件,否則最好使用分區(qū)存儲(chǔ)。
使用分區(qū)存儲(chǔ)的應(yīng)用對(duì)自己創(chuàng)建的文件始終擁有讀/寫權(quán)限,無論文件是否位于應(yīng)用的專有目錄內(nèi) 。這說明了默認(rèn)分區(qū)存儲(chǔ)內(nèi)的文件也只有應(yīng)用自己能看到,就像是沙盒內(nèi),同時(shí) getExternalFilesDir()
下的文件會(huì)隨著應(yīng)用卸載而清除。
也就是說應(yīng)用可以無需申請(qǐng)任何權(quán)限使用 getExternalFilesDir()
、 MediaStore
和 SAF
讀寫文件, 當(dāng)然如果使用 MediaStore
讀取其他應(yīng)用的媒體集合時(shí),是需要 READ_EXTERNAL_STORAGE
。
而 MediaStore
中支持的類型有:
另外還有其他的限制,比如:
- 應(yīng)用沒有
ACCESS_MEDIA_LOCATION
權(quán)限,那么訪問到的媒體資源中的Exif
元數(shù)據(jù)會(huì)被修改. - 使用
MediaStore.Files
也僅顯示照片、視頻和音頻文件,例如不會(huì)顯示表中的 PDF 文件。
總結(jié)起來結(jié)論就是:
- 1、獲取系統(tǒng)相冊(cè)、視頻,圖片等需要通過
SAF
,利用ContentResolver
的Cursor
來提供。 - 2、訪問公有目錄也需要通過
MediaStore
和ContentResolver
,比如保存圖片到外部公共存儲(chǔ),拷貝文件到 Download 目錄等等。 - 3、比如
new File(path).createNewFile();
等的判斷在公共目錄下不能再用了。
簡(jiǎn)單來說就是:應(yīng)用在自己的沙盒內(nèi)可以“為所欲為”,通過 MediaStore
可以分類整理文件,通過 SAF
可以訪問其他應(yīng)用的公共媒體文件。
-
Android
+關(guān)注
關(guān)注
12文章
3903瀏覽量
126612 -
華為
+關(guān)注
關(guān)注
215文章
34128瀏覽量
249453 -
API
+關(guān)注
關(guān)注
2文章
1461瀏覽量
61489
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論