App的版本从22升到25出现的问题记录

在将Android应用从版本22升级到25时遇到了多个问题,包括Manifest merger失败和第三方库MultiImageSelector在拍照时崩溃。解决Manifest merger失败的关键在于处理authorities冲突,通过添加tools:replace="authorities"来修复。同时,针对拍照崩溃,发现从文件获取Uri在API 25上不再适用,需进行调整。

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

由于同事要引入一个视频监控的库文件,所以最近在开发的一个App不得不从22升到25,然而升到25之后各种问题就涌现了,记录一下。

问题一:使用的MultiImageSelector第三方库在拍照时发生crash的问题。

原因:在版本为25时,从文件获取Uri,不能再使用Uri.fromFile("文件名")。例如在该第三方库的MultiImageSelectorFragment类中,有这样一行代码:

intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(mTmpFile));

我们需要把它如下

Uri tmpFileURI = FileProvider.getUriForFile(this.getContext(), this.getActivity().getApplicationContext().getPackageName() + ".provider", mTmpFile);               intent.putExtra(MediaStore.EXTRA_OUTPUT, tmpFileURI);
在上面的代码中我们看到一个".provider",这个是就是我们自己创建的一个存放文件的路径,首先我们要在清单文件的Application下面加上这样一段配置:

<provider
            android:authorities="me.nereo.multi_image_selector.provider"
            android:name="android.support.v4.content.FileProvider"
            android:grantUriPermissions="true"
            android:exported="false">
            <meta-data
                android:name="android.support.FILE_PROVIDER_PATHS"
                android:resource="@xml/file_paths"/>
</provider>
其中me.nereo.multi_image_selector就是包名,也就是说authorities要设置成"包名.provider",当然这个provider也可以设置成任意名字,但一定要保证和getUriForFile方法里面的一致,不然会找不到。接着我们要在res目录下新建一个“xml”的文件夹,在里面新建一个文件,文件中的代码如下:

<?xml version="1.0" encoding="utf-8"?>
<paths>
    <!-- external-path:sd ;path:你的应用保存文件的根目录;name随便定义-->
    <!-- root-path 手机存储根目录 -->
    <root-path path="." name="multi_image_selector" />
</paths>
这样我们就解决crash的问题,同样地如果我们在调用拍视频时也用到了Uri的fromFile()方法也是这样改,我的项目中就碰到了这样的情况。不过由于我在项目的清单文件中也用到了<provider android: authorities ... />,所以出现了一个bug:

Manifest merger failed with multiple errors

有没有觉得这个bug很眼熟,其实就是authorities重复了,加上一句 tools:replace="authorities"就解决了。


问题二:获取手机deviceId发生crash,这个就涉及到动态权限获取了,网上解决方法很多,就不赘述了。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值