android - 找不到类“androidx.core.content.FileProvider”
问题描述
我将我的应用程序迁移到 AndroidX,它在 API 级别 21 上启动时崩溃。我的应用程序抛出此异常:
10-08 09:42:50.930 11346-11346/com.example.test E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.test, PID: 11346
java.lang.RuntimeException: Unable to get provider androidx.core.content.FileProvider: java.lang.ClassNotFoundException: Didn't find class "androidx.core.content.FileProvider" on path: DexPathList[[zip file "/data/app/com.example.test-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.example.test-1, /vendor/lib, /system/lib]]
at android.app.ActivityThread.installProvider(ActivityThread.java:5121)
at android.app.ActivityThread.installContentProviders(ActivityThread.java:4713)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4596)
at android.app.ActivityThread.access$1600(ActivityThread.java:169)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1340)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:146)
at android.app.ActivityThread.main(ActivityThread.java:5487)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassNotFoundException: Didn't find class "androidx.core.content.FileProvider" on path: DexPathList[[zip file "/data/app/com.example.test.apk"],nativeLibraryDirectories=[/data/app-lib/com.example.test-1, /vendor/lib, /system/lib]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:67)
at java.lang.ClassLoader.loadClass(ClassLoader.java:497)
at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
at android.app.ActivityThread.installProvider(ActivityThread.java:5106)
at android.app.ActivityThread.installContentProviders(ActivityThread.java:4713)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4596)
at android.app.ActivityThread.access$1600(ActivityThread.java:169)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1340)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:146)
at android.app.ActivityThread.main(ActivityThread.java:5487)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
at dalvik.system.NativeStart.main(Native Method)
这是provider
我的 AndroidManifest.xml 文件中的定义:
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.fileProvider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/provider_paths" />
</provider>
在最新的 API 级别上,它运行良好。任何建议都会很有用,在此先感谢。
解决方案
似乎此错误来自您的应用程序中 MultiDex 的不完整配置。在这里你可能会发现类似的问题,这里有一篇回答它的文章。
我建议您检查以下内容(扩展 App 类对我有帮助):
您的应用程序类(例如 App.class,如果您使用它)应该从 MultiDexApplication 类扩展:
public class BaseApplication extends MultiDexApplication {}
或者如果您不使用 Application 类,请检查您的清单:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.android.multidex.myapplication">
<application
...
android:name="android.support.multidex.MultiDexApplication">
...
</application>
</manifest>
推荐阅读
- c# - 为什么当我使用 gPRC 在 .Net Framework(非核心)中获取请求数据时出现运行时错误?
- reactjs - 在 nextjs API 请求中获取 cookie/localStorage 值
- c# - 如何将时间戳添加到表格编辑器属性导出?- C#
- typescript - 打字稿:如何重载受保护的类常量
- typescript - TS 编译器没有抱怨可能的未定义对象解构?
- python - 尝试从 Python 中的 JSON 文件中获取数据
- php - 获取标签值的简单 HTML Dom
- list - 如何添加列表
到 CheckboxListTile 值? - node.js - 使用 type-graphql 和 typegoose 处理嵌套的输入类型
- javascript - 是什么决定了节点是打印 `[object Object]` 还是一个完整的对象?