关于Android7.0的Filede URL问题的解决

android.os.FileUriExposedException: file:///storage/emulated/0/gridview/1519870496425_temp_photo.jpg exposed beyond app through ClipData.Item.getUri()

这个问题是在android7.0上进行拍照的时候搞URl的事情出现的,这是因为从Android 7.0开始,一个应用提供自身文件给其它应用使用时,如果给出一个file://格式的URI的话,应用会抛出FileUriExposedException。这是由于谷歌认为目标app可能不具有文件权限,会造成潜在的问题。所以让这一行为快速失败。这就很基督了,对待用户像春天般温暖,对待开发者像严冬般寒冷,从6.0的权限哦动态申请到7.0的uri暴露问题,导致原本一行代码解决,现在凭空多了无数行代码,哼哼哼,不过这样子也好,方便用户,保护隐私,也是咱们开发者应该做的,接下来是谷歌官方推荐的解决办法,

1.在AndroidManifest.xml中添加如下代码,其实就是在manifest中声明一个《provider》。name(即类名)为android.support.v4.content.FileProvider。

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="">
    ...

    <application
        >
        ...
        <provider
            android:name="android.support.v4.content.FileProvider"
            android:authorities="${applicationId}.provider"
            android:exported="false"
            android:grantUriPermissions="true">
            <meta-data
                android:name="android.support.FILE_PROVIDER_PATHS"
                android:resource="@xml/provider_paths"/>
        </provider>
...
    </application>
    ...
</manifest>

2.在res目录下新建一个xml文件夹,并且新建一个provider_paths的xml文件

<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
    <!--"."表示所有路径-->
    <external-path name="external_files" path="."/>
</paths>

3.使用到uri的代码

“` Uri photoURI = Uri.fromFile(createImageFile());

变成:

Uri photoURI = FileProvider.getUriForFile(context,
context.getApplicationContext().getPackageName() + “.provider”,
createImageFile()); “`

**是不是感觉好简单啊,哈哈哈,我逗你的,接下来是更简单的方法: VmPolicy方式
在Application.onCreate加入如下代码,置入一个不设防的VmPolicy:

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
StrictMode.VmPolicy.Builder builder = new StrictMode.VmPolicy.Builder();
StrictMode.setVmPolicy(builder.build()); }

这个方法是不是很简单呢,是啊,那么问题来了,原理是什么,我不晓得,原博客作者也没有写清楚,没错,第二种是我照着博客作者来的,接下来给出原博客作者地址:
http://blog.csdn.net/xiaoyu940601/article/details/54406725,大家可以去看看

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值