今天遇到一个下载安装apk失败是因为
Google反对放宽私有目录的访问权限的,所以收起对私有文件的访问权限是Android将来发展的趋势。
Android7.0之后直接使用本地的根目录即file:// URI是不安全的操作,所以会触发 FileUriExposedException
这就意味着在Android7.0以前我们访问相机拍照存储时,如果使用URI的方式直接存储剪裁图片就会造成这个异常
因此Google为我们提供了FileProvider类,FileProvider时ContentProvide的子类,ContentProvide是Android的四大组件之一,它使用了和内容提供器类似的机制来对数据进行保护,可以选择性地将封装过的Uri共享给外部,从而提高了应用的安全性。
使用FileProvider获取Uri就会将以前的file:// URI准换成content:// URI,实现一种安全的应用间数据访问
使用FileProvider需要在清单文件AndroidManifest.xml中进行注册的:
<provider
android:name="android.support.v4.content.FileProvider"
android:authorities="你的包名.FileProvider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/apk_provider_paths" />
<