我只是在Google Play控制台中检查我的一个Android应用的ANR和崩溃。
我随机选择打开“崩溃”选项卡上的“显示隐藏”开关(不知道隐藏与不隐藏是什么意思,这是我第一次打开它),我在列表的顶部看到了崩溃每天发生数百次,并影响数百名用户。
我从堆栈跟踪中收集了与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个相应的文件:
这是一个Apache Cordova项目,因此这些条目的生成者是:
每个XML文件包含相同的内容:
<paths xmlns:android="http://schemas.android.com/apk/res/android">
<external-path name="external_files" path="."/>
</paths>
答案 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