没找到 class "androidx.core.content.FileProvider"
Didn't find class "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.access00(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.access00(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)
这是我的 AndroidManifest.xml 文件中的 provider
定义:
<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 配置不完整造成的。 Here you may find the similar issue and here 是一篇回答它的文章。
我建议您检查以下内容(扩展 App class 帮助了我):
您的应用程序 class(App.class,例如,如果您使用它)应该从 MultiDexApplication class:
扩展
public class BaseApplication extends MultiDexApplication {}
或者,如果您不使用应用程序 class,请检查您的清单:
<?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>
问题是你的 React Native android 项目不在 AndroidX 而 react-native-image-picker
在 AndroidX 环境;因此,它缺少 androidx 包库中的包。
简单的修复方法是将以下行添加到您的 ./android/gradle.properties
文件中:
android.useAndroidX=true
android.enableJetifier=true
如果您有任何使用旧 android 包的现有 RN 库,您的项目将无法构建,因为一旦您更新项目,它们就会丢失。
这里有一个聪明的工具可以处理使用旧 android 包的 RN 库并使它们更新。
npm i --save-dev jetifier
npx jetify
react-native run-android
全部检查完毕,我这边正在使用。希望这对任何人都有帮助,如果有帮助请分享。
如果您使用了外部库,请为您的项目添加以下 ndk 库支持 -
ndk
{
abiFilters "armeabi-v7a", "x86", "x86_64", "arm64-v8a"
}
在您的应用级别的默认配置中 build.gradle 文件
defaultConfig
{
applicationId "org.comcast.net"
minSdkVersion 21
targetSdkVersion 28
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
ndk
{
abiFilters "armeabi-v7a", "x86", "x86_64", "arm64-v8a"
}
}
它已经解决了我的问题,希望它也能解决你的问题。
文档已过时;将 androidx.multidex
用于 androidx
:
implementation "androidx.multidex:multidex:2.0.1"
AndroidManifest.xml
:
<application
android:name="androidx.multidex.MultiDexApplication">
</application>
在 Jetifier 仍然使用任何 com.android.support
库时使用它:
android.enableJetifier=true
我将我的应用程序迁移到 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.access00(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.access00(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)
这是我的 AndroidManifest.xml 文件中的 provider
定义:
<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 配置不完整造成的。 Here you may find the similar issue and here 是一篇回答它的文章。
我建议您检查以下内容(扩展 App class 帮助了我):
您的应用程序 class(App.class,例如,如果您使用它)应该从 MultiDexApplication class:
扩展public class BaseApplication extends MultiDexApplication {}
或者,如果您不使用应用程序 class,请检查您的清单:
<?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>
问题是你的 React Native android 项目不在 AndroidX 而 react-native-image-picker
在 AndroidX 环境;因此,它缺少 androidx 包库中的包。
简单的修复方法是将以下行添加到您的 ./android/gradle.properties
文件中:
android.useAndroidX=true
android.enableJetifier=true
如果您有任何使用旧 android 包的现有 RN 库,您的项目将无法构建,因为一旦您更新项目,它们就会丢失。
这里有一个聪明的工具可以处理使用旧 android 包的 RN 库并使它们更新。
npm i --save-dev jetifier
npx jetify
react-native run-android
全部检查完毕,我这边正在使用。希望这对任何人都有帮助,如果有帮助请分享。
如果您使用了外部库,请为您的项目添加以下 ndk 库支持 -
ndk
{
abiFilters "armeabi-v7a", "x86", "x86_64", "arm64-v8a"
}
在您的应用级别的默认配置中 build.gradle 文件
defaultConfig
{
applicationId "org.comcast.net"
minSdkVersion 21
targetSdkVersion 28
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
ndk
{
abiFilters "armeabi-v7a", "x86", "x86_64", "arm64-v8a"
}
}
它已经解决了我的问题,希望它也能解决你的问题。
文档已过时;将 androidx.multidex
用于 androidx
:
implementation "androidx.multidex:multidex:2.0.1"
AndroidManifest.xml
:
<application
android:name="androidx.multidex.MultiDexApplication">
</application>
在 Jetifier 仍然使用任何 com.android.support
库时使用它:
android.enableJetifier=true