java - 从 firebase-crashlytics 18.3.3 更新到 18.3.4 时 Android 应用程序崩溃

标签 java android firebase crashlytics

似乎从 '实现 com.google.firebase:firebase-crashlytics:18.3.3''实现 com.google.firebase:firebase-crashlytics:18.3.4' 应用程序初始化时会生成以下崩溃日志。我可能缺少任何依赖项吗?

2023-02-14 23:43:27.026 13135-13135/ I/MultiDex: VM has multidex support, MultiDex support library is disabled.
2023-02-14 23:43:27.052 13135-13135/ D/AndroidRuntime: Shutting down VM
2023-02-14 23:43:27.054 13135-13135/ E/AndroidRuntime: FATAL EXCEPTION: main
    Process: , PID: 13135
    java.lang.NoClassDefFoundError: Failed resolution of: Lcom/google/firebase/annotations/concurrent/Background;
        at com.google.firebase.installations.FirebaseInstallationsRegistrar.getComponents(FirebaseInstallationsRegistrar.java:45)
        at com.google.firebase.tracing.ComponentMonitor.processRegistrar(ComponentMonitor.java:28)
        at com.google.firebase.components.ComponentRuntime.discoverComponents(ComponentRuntime.java:117)
        at com.google.firebase.components.ComponentRuntime.<init>(ComponentRuntime.java:99)
        at com.google.firebase.components.ComponentRuntime.<init>(ComponentRuntime.java:46)
        at com.google.firebase.components.ComponentRuntime$Builder.build(ComponentRuntime.java:387)
        at com.google.firebase.FirebaseApp.<init>(FirebaseApp.java:437)
        at com.google.firebase.FirebaseApp.initializeApp(FirebaseApp.java:303)
        at com.google.firebase.FirebaseApp.initializeApp(FirebaseApp.java:271)
        at com.google.firebase.FirebaseApp.initializeApp(FirebaseApp.java:256)
        at com.google.firebase.provider.FirebaseInitProvider.onCreate(FirebaseInitProvider.java:51)
        at android.content.ContentProvider.attachInfo(ContentProvider.java:2404)
        at android.content.ContentProvider.attachInfo(ContentProvider.java:2374)
        at com.google.firebase.provider.FirebaseInitProvider.attachInfo(FirebaseInitProvider.java:45)
        at android.app.ActivityThread.installProvider(ActivityThread.java:7422)
        at android.app.ActivityThread.installContentProviders(ActivityThread.java:6939)
        at android.app.ActivityThread.handleBindApplication(ActivityThread.java:6710)
        at android.app.ActivityThread.access$1500(ActivityThread.java:247)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2053)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loopOnce(Looper.java:201)
        at android.os.Looper.loop(Looper.java:288)
        at android.app.ActivityThread.main(ActivityThread.java:7839)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:548)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1003)
     Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.firebase.annotations.concurrent.Background" on path: DexPathList[[zip file "/data/app/~~s71FMMPQjbON5bHQXPtW2w==/-mUP09Nn8ZAhW8aCE_JxV8w==/base.apk"],nativeLibraryDirectories=[/data/app/~~s71FMMPQjbON5bHQXPtW2w==/-mUP09Nn8ZAhW8aCE_JxV8w==/lib/x86_64, /data/app/~~s71FMMPQjbON5bHQXPtW2w==/-mUP09Nn8ZAhW8aCE_JxV8w==/base.apk!/lib/x86_64, /system/lib64, /system_ext/lib64]]
        at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:218)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
        at com.google.firebase.installations.FirebaseInstallationsRegistrar.getComponents(FirebaseInstallationsRegistrar.java:45) 
        at com.google.firebase.tracing.ComponentMonitor.processRegistrar(ComponentMonitor.java:28) 
        at com.google.firebase.components.ComponentRuntime.discoverComponents(ComponentRuntime.java:117) 
        at com.google.firebase.components.ComponentRuntime.<init>(ComponentRuntime.java:99) 
        at com.google.firebase.components.ComponentRuntime.<init>(ComponentRuntime.java:46) 
        at com.google.firebase.components.ComponentRuntime$Builder.build(ComponentRuntime.java:387) 
        at com.google.firebase.FirebaseApp.<init>(FirebaseApp.java:437) 
        at com.google.firebase.FirebaseApp.initializeApp(FirebaseApp.java:303) 
        at com.google.firebase.FirebaseApp.initializeApp(FirebaseApp.java:271) 
        at com.google.firebase.FirebaseApp.initializeApp(FirebaseApp.java:256) 
        at com.google.firebase.provider.FirebaseInitProvider.onCreate(FirebaseInitProvider.java:51) 
        at android.content.ContentProvider.attachInfo(ContentProvider.java:2404) 
        at android.content.ContentProvider.attachInfo(ContentProvider.java:2374) 
        at com.google.firebase.provider.FirebaseInitProvider.attachInfo(FirebaseInitProvider.java:45) 
        at android.app.ActivityThread.installProvider(ActivityThread.java:7422) 
        at android.app.ActivityThread.installContentProviders(ActivityThread.java:6939) 
        at android.app.ActivityThread.handleBindApplication(ActivityThread.java:6710) 
        at android.app.ActivityThread.access$1500(ActivityThread.java:247) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2053) 
        at android.os.Handler.dispatchMessage(Handler.java:106) 
        at android.os.Looper.loopOnce(Looper.java:201) 
        at android.os.Looper.loop(Looper.java:288) 
        at android.app.ActivityThread.main(ActivityThread.java:7839) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:548) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1003) 
2023-02-14 23:43:28.677 13135-13147/ W/System: A resource failed to call close. 

我的模块 build.gradle 有这些依赖项

dependencies {
    implementation platform('com.google.firebase:firebase-bom:30.4.1')

    implementation 'androidx.multidex:multidex:2.0.1'
    implementation 'androidx.appcompat:appcompat:1.6.1'
    implementation 'com.google.android.material:material:1.8.0'
    implementation 'androidx.constraintlayout:constraintlayout:2.1.4'
    implementation 'androidx.navigation:navigation-fragment:2.5.3'
    implementation 'androidx.navigation:navigation-ui:2.5.3'
    implementation 'androidx.preference:preference:1.2.0'
    implementation 'androidx.legacy:legacy-support-v4:1.0.0'
    testImplementation 'junit:junit:4.13.2'
    androidTestImplementation 'androidx.test.ext:junit:1.1.5'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.5.1'
    implementation 'androidx.swiperefreshlayout:swiperefreshlayout:1.1.0'
    implementation 'com.android.volley:volley:1.2.1'
    implementation 'androidx.core:core:1.9.0'

    implementation 'com.google.firebase:firebase-analytics:21.2.0'
    implementation 'com.google.firebase:firebase-database:20.1.0'
    implementation 'com.google.firebase:firebase-messaging:23.1.1'
    implementation 'com.google.firebase:firebase-crashlytics:18.3.4'

    implementation 'com.google.android.gms:play-services-maps:18.1.0'
    implementation 'com.google.android.gms:play-services-analytics:18.0.2'
    implementation 'com.google.android.gms:play-services-location:21.0.1'

    implementation 'com.google.android.gms:play-services-auth:20.4.1'
    implementation 'com.google.android.gms:play-services-auth-api-phone:18.0.1'

    implementation "com.github.parse-community.Parse-SDK-Android:parse:1.26.0"

    implementation 'androidx.camera:camera-camera2:1.3.0-alpha02'
    implementation "androidx.camera:camera-lifecycle:1.2.1"
    implementation 'androidx.camera:camera-view:1.3.0-alpha02'

    implementation 'com.google.zxing:core:3.5.0'
    implementation 'com.google.code.gson:gson:2.9.1'
}

apply plugin: 'com.google.firebase.crashlytics'

我的项目build.gradle有以下依赖项

 dependencies {
        classpath 'com.android.tools.build:gradle:7.2.2'
        classpath 'com.google.gms:google-services:4.3.15'
        classpath 'com.google.firebase:firebase-crashlytics-gradle:2.9.4'
        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }

我知道我可以继续使用版本 18.3.3,但我试图理解为什么会发生此崩溃。

最佳答案

正如 @Nitish 所评论的,BoM 版本不支持该版本的 Crashlytics。所以我更新了BoM版本并删除了特定产品版本上的版本。我的应用程序 build.gradle 依赖项现在如下所示:

dependencies { ....
implementation platform('com.google.firebase:firebase-bom:31.2.0')

implementation 'com.google.firebase:firebase-analytics'
implementation 'com.google.firebase:firebase-database'
implementation 'com.google.firebase:firebase-messaging'
implementation 'com.google.firebase:firebase-crashlytics' ....

与撰写本文时的最新版本一致,取自 Firebase现在,该应用程序可以构建并运行,而不会在启动时崩溃。 Firebase此处还表明我不必指定特定 Firebase 产品的版本。

关于java - 从 firebase-crashlytics 18.3.3 更新到 18.3.4 时 Android 应用程序崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/75459758/

相关文章:

java - 如何使用 facebook sdk 版本 3.22.0 从 Facebook 登录获取 emailid

java - 使用brew构建OpenCV时设置目标java版本

android - 创建以日期作为列标题的 mysql 表

android - Firebase 电话身份验证 : Does white listing real numbers cause an sms to be sent?

java - 如何在 Java 中旋转 imageIcon

java - 为非默认模块选择本地开发服务器上的特定端口

android - 以完整长度截取 RecyclerView 的屏幕截图.. 每个项目都有一个列表

android - 如何使用 A/B 测试根据城市为指定用户启用 Android 应用程序中的特定功能

android - FCM : Displaying emoji or UTF-8 text on iOS that is sent from Android device

javascript - 从 javascript 表下载存储在 firebase 数据库中的文件