在开发过程中,要实现意见反馈的图片选择上传功能,进入相册选择后可以看到自己选择了什么图片,然而在获取到下列三个权限后,
android.permission.READ_EXTERNAL_STORAGE android.permission.WRITE_EXTERNAL_STORAGE android.permission.CAMERA
选择图片后返回上传图片失败,查看Log,已经获取图片信息,但是上传失败:
HTTP FAILED: java.io.FileNotFoundException: /storage/emulated/0/Pictures/_storage_emulated_0_Android_data_com.fw.laqhj_files_Pictures_DCIM_Camera_120248.jpg: open failed: EACCES (Permission denied)
百思不得其解后,发现可能是Android Q搞的鬼,于是看了下开发者文档.
https://developer.android.google.cn/training/data-storage/files/external-scoped?hl=zh_cn
原来为了能给用户提供对文件的更多控制并限制文件混乱,Android Q改变了应用程序访问设备外部存储上文件的方式,例如存储在路径/ sdcard中的文件。Android Q继续使用READ_EXTERNAL_STORAGE和WRITE_EXTERNAL_STORAGE权限,这些权限对应于存储面向用户的运行时权限。但是,默认情况下targetSdkVersion设置为Android Q的应用(以及manifest清单开启属性来启动这个变更的应用)会获得一个沙盒视图到外部存储。此类应用程序只能看到其特定于应用程序的目录和特定媒体类型,因此应用程序不需要请求任何其他用户权限。
也就是说从Android Q(10.0) sdk>=29 开始,系统为每个app提供了一个隔离环境(分区存储),参考下列资料,有十分详细的说明,这里给出解决办法。
解决办法:在 AndroidManifest.xml 中加入 android:requestLegacyExternalStorage=“true”
原理:加入这句代码之后会启动兼容模式:停用分区存储,但是要留意的是
警告:2020年,主要平台版本将要求所有应用都使用分区存储,无论应用的目标 SDK 级别是多少。因此,您应该提前确保您的应用能够使用分区存储。为此,请确保针对搭载 Android 10(API 级别 29)及更高版本的设备启用了该行为。
Google日常搞事情,估计明年又会有啥名堂吧。