一、前言:
随着安卓系统的不断更新,很多业务代码也要跟着更新,否则经常会有意想不到的错误发生。比如在安卓Q(10)开始,就采用存储的分区控制。导致明明已经申请了android.permission.WRITE_EXTERNAL_STORAGE权限,却还是报错open failed: EACCES (Permission denied)。只能通过手动打开权限,还能使用存储权限。
1、上传到亚马逊服务器报错:
com.amazonaws.AmazonClientException: Unable to calculate MD5 hash: /storage/emulated/0/Pictures/DCIM/20231026104618_CROP.jpg: open failed: EACCES (Permission denied)
2、相册路径上传到亚马逊服务器报错(相机路径是OK的):
//相机路径:/storage/emulated/0/Android/data/com.kana.crazytv/files/Pictures/20231026100315.jpg
//相册路径:/storage/emulated/0/Pictures/DCIM/20231026100444_CROP.jpg
3、解决办法是在manifest的applicaiton标签添加 :
android:requestLegacyExternalStorage="true"
标识,问题便解决了。如图:
![](https://img.haomeiwen.com/i11268516/46ad3afc10685e67.png)
二、分析:
分析原因:Android Q文件存储机制修改成了沙盒模式,有点模仿苹果的意思。APP只能访问自己目录下的文件和公共媒体文件。对于AndroidQ以下,还是使用老的文件存储方式。Android Q仍然使用READ_EXTERNAL_STORAGE和WRITE_EXTERNAL_STORAGE作为存储相关运行时权限,但现在即使获取了这些权限,访问外部存储也受到了限制。
android:requestLegacyExternalStorage="true"
的意思就是使用旧的存储策略,不使用androidQ的新策略。但这个不是长久之计,很快将会强制都使用新策略。最好的解决策略就是
1、需要长期保存并且卸载也不能删除的,使用公有目录
公有目录:Downloads、Documents、Pictures 、DCIM、Movies、Music、Ringtones等
- 地址:/storage/emulated/0/Downloads(Pictures)等
- 公有目录下的文件不会跟随APP卸载而删除。
2、不需要长期保存的,并且涉及安全问题的,使用私有目录
- APP私有目录
- 地址:/storage/emulated/0/Android/data/包名/files
网友评论