由于android.support.v4.content.FileProvider.parsePathStrategy而导致Android崩溃

时间:2019-04-01 17:20:02

标签: android cordova crash cordova-plugins android-support-library

我只是在Google Play控制台中检查我的一个Android应用的ANR和崩溃。

我随机选择打开“崩溃”选项卡上的“显示隐藏”开关(不知道隐藏与不隐藏是什么意思,这是我第一次打开它),我在列表的顶部看到了崩溃每天发生数百次,并影响数百名用户。

enter image description here

我从堆栈跟踪中收集了与Android支持库有关的信息,但我不知道是什么原因,到目前为止,谷歌搜索堆栈跟踪行并没有发现任何有用的信息。

这只是在3月22日发布新的次要应用程序版本时才开始发生的,但是从回购历史记录中可以看到,我所做的更改非常次要,因此请不要解释。

这是堆栈跟踪:

java.lang.NullPointerException in android.support.v4.content.FileProvider.parsePathStrategy

java.lang.RuntimeException: 
  at android.app.ActivityThread.installProvider (ActivityThread.java:6643)
  at android.app.ActivityThread.installContentProviders (ActivityThread.java:6185)
  at android.app.ActivityThread.handleInstallProvider (ActivityThread.java:3452)
  at android.app.ActivityThread$H.handleMessage (ActivityThread.java:1939)
  at android.os.Handler.dispatchMessage (Handler.java:106)
  at android.os.Looper.loop (Looper.java:193)
  at android.app.ActivityThread.main (ActivityThread.java:6923)
  at java.lang.reflect.Method.invoke (Native Method)
  at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run (RuntimeInit.java:493)
  at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:870)
Caused by: java.lang.NullPointerException: 
  at android.support.v4.content.FileProvider.parsePathStrategy (FileProvider.java:584)
  at android.support.v4.content.FileProvider.getPathStrategy (FileProvider.java:558)
  at android.support.v4.content.FileProvider.attachInfo (FileProvider.java:376)
  at android.app.ActivityThread.installProvider (ActivityThread.java:6638)

我认为this is the line在Android支持库的堆栈跟踪中被引用。

任何想法可能是什么原因?

更新

更多挖掘,我在AndroidManifest.xml内的<application>中找到了这3个条目:

<provider android:authorities="${applicationId}.provider" android:exported="false" android:grantUriPermissions="true" android:name="android.support.v4.content.FileProvider">
  <meta-data android:name="android.support.FILE_PROVIDER_PATHS" android:resource="@xml/provider_paths"/>
</provider>
<provider android:authorities="${applicationId}.provider" android:exported="false" android:grantUriPermissions="true" android:name="de.appplant.cordova.emailcomposer.Provider">
  <meta-data android:name="android.support.FILE_PROVIDER_PATHS" android:resource="@xml/emailcomposer_provider_paths"/>
</provider>
<provider android:authorities="${applicationId}.provider" android:exported="false" android:grantUriPermissions="true" android:name="de.appplant.cordova.plugin.notification.util.AssetProvider">
  <meta-data android:name="android.support.FILE_PROVIDER_PATHS" android:resource="@xml/localnotification_provider_paths"/>

res/xml/中有3个相应的文件:

  • provider_paths.xml
  • localnotification_provider_paths.xml
  • emailcomposer_provider_paths.xml

这是一个Apache Cordova项目,因此这些条目的生成者是:

每个XML文件包含相同的内容:

<paths xmlns:android="http://schemas.android.com/apk/res/android">
    <external-path name="external_files" path="."/>
</paths>

1 个答案:

答案 0 :(得分:2)

我终于找到了这些崩溃的原因,这些崩溃似乎是由于提供者授权名称冲突引起的。

我将授权机构的名称更改为唯一,现在在Play商店中以更新形式发布了授权,崩溃已不再报告为最新版本:

android:authorities="${applicationId}.camera.provider
android:authorities="${applicationId}.emailcomposer.provider
android:authorities="${applicationId}.localnotification.provider

作为参考,我在Github问题中找到了以下信息: https://github.com/katzer/cordova-plugin-local-notifications/issues/1664