android.os.FileUriExposedException: file://xxx

本文介绍了在Android7.0及以上版本中,由于系统限制,直接使用file:// URI会导致FileUriExposedException异常。为了解决这个问题,文章推荐使用FileProvider,它是一个ContentProvider子类,能安全地分享文件。通过在AndroidManifest.xml中注册FileProvider,并配置共享路径,可以将file:// URI转换为content:// URI,避免安全问题。同时,文章还提到了在清单文件中的配置细节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天遇到一个下载安装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" />
    <
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值