Android N 文件系统权限发生了变化 ,为了提高私有文件的安全性,在targetSdk版本为N或者以后版本的app中,其私有目录将会限制访问。这可以防止私有文件元数据的泄露,比如文件大小或者是文件是否存在。但这给开发者带来了很多不利的影响:
文件的owner不能放宽文件权限,如果你使用MODE_WORLD_READABLE或者 MODE_WORLD_WRITEABLE操作文件,将会触发SecurityException。
当你跨package域传递file://的URI时,接收者得到的将是一个无权访问的路径,因此,这将会触发FileUriExposedException。
对于这类操作,官方推荐的方式是使用FilePRovider,当然你也可以使用ContentProvider。
这里兼容我采用的是ContentProvider,当然也可以使用Google官方推荐的FileProvider,这里我给出地址Demo,有兴趣的可以看下。FileProvider Demo
新闻热点
疑难解答