Failed to find configured root that contains xxxx 的一次踩坑之旅

背景

在升级targetSDK的时候,应用崩溃并抛出:

Failed to find configured root that contains xxxx

但是,由于网上资料与博客众多,这一篇文章并不是讲述如何使用FileProvider向外传送内部Uri,并且实际尚,我已经对应用进行了一次FileProvider的改造,我也不想再撰写重复的教程来指导你如何改造,所以这篇文章只是一次填坑之旅的记录而已。

先描述崩溃的背景:

崩溃发生在调用摄像头试图拍照的时候,向摄像机的Intent传递了一个内部的Uri。当然我们知道,这个如果没经过FileProvider的处理,确实会发生崩溃,但是,其实我已经对这部分做了FileProvider的处理了。有一点稍微特殊的是,我们的图片选择器是作为库的形式编译到我们的主工程中的(就是图片选择库是在gradle中引入的)。
而在升级targetSDK的时候,我已经对这个库做了升级处理,在单独运行这个库(这个库带一个简易的运行app壳)的时候,能正常运行。

出事的代码:

cameraPath = cameraFile.getAbsolutePath();
Uri uri = ImagePickerFileProvider.getUriForFile(activity, "com.xxxx.xxx.xx.x", cameraFile);
cameraIntent.putExtra(MediaStore.EXTRA_OUTPUT, uri);
activity.startActivityForResult(cameraIntent, ImageSelectorActivity.REQUEST_CAMERA);

Manifest:


            

        

and provider_paths.xml :




    

    


(以上xxx为信息隐藏)

一切都非常地正确,而且在壳app(也就是图片选择库自带一个运行app)上确实能运行正常,一到了主app上运行就崩溃。而且这里的external-path的配置确实没有问题,出事的文件路径也是

Environment.getExternalStorageDirectory() + "xxx"

解决方案

先公布我的解决方案吧,让着急着找解决方案的朋友先把问题解决了:
在我的主app中,也定义了一个FileProvider(后称AppFileProvider),而AppFileProvider的paths配置文件名也是 provider_paths.xml,在项目编译的时候,图片选择器库的provider_paths.xml文件被主工程的provider_paths.xml给覆盖了,导致库工程的FileProvider的配置失效,那么在 xxx目录下的文件的FileProvider转换自然也就会失败了。
所以最终我的解决方案是:所有FileProvider的xml配置文件都单独命名,不使用同一个名字
同时我也建议各位在使用FileProvider的时候,新创建一个类来继承FileProvider并注册到Manifest,同时在配置xml文件时,也使用唯一的命名。

Ps,附一篇 编译时替换资源 - Android重叠包与资源合并一见 ,有需要的同学可以接着看

你可能感兴趣的:(Failed to find configured root that contains xxxx 的一次踩坑之旅)