FirebaseCrashlytics:设置请求失败

15

我快完成我的安卓应用了,但我想添加FirebaseCrashlytics。我总是添加这个库而且从来没有安装出现问题。但现在情况不同了。我遇到了以下错误:

2021-05-24 20:41:42.807 11296-11333/com.example.depeuleschil E/FirebaseCrashlytics: Settings request failed.
java.io.FileNotFoundException: https://firebase-settings.crashlytics.com/spi/v2/platforms/android/gmp/1:966637647957:android:9f830999a842bf19b5fcdc/settings?instance=864af142db1afeaf05a53d2c5a0bee2a10c2f546&build_version=1&display_version=1.0&source=1
    at com.android.okhttp.internal.huc.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:255)
    at com.android.okhttp.internal.huc.DelegatingHttpsURLConnection.getInputStream(DelegatingHttpsURLConnection.java:211)
    at com.android.okhttp.internal.huc.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:30)
    at com.google.firebase.crashlytics.internal.network.HttpGetRequest.execute(HttpGetRequest.java:80)
    at com.google.firebase.crashlytics.internal.settings.network.DefaultSettingsSpiCall.invoke(DefaultSettingsSpiCall.java:113)
    at com.google.firebase.crashlytics.internal.settings.SettingsController$1.then(SettingsController.java:199)
    at com.google.firebase.crashlytics.internal.settings.SettingsController$1.then(SettingsController.java:192)
    at com.google.android.gms.tasks.zzp.run(Unknown Source:2)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
    at com.google.firebase.crashlytics.internal.common.ExecutorUtils$1$1.onRun(ExecutorUtils.java:64)
    at com.google.firebase.crashlytics.internal.common.BackgroundPriorityRunnable.run(BackgroundPriorityRunnable.java:27)
    at java.lang.Thread.run(Thread.java:923)

我已经在 Google 上花了 2 小时,Stackoverflow 上有一些人遇到了相同类型的问题。但问题总是略有不同,我已经尝试了 Stackoverflow 上能找到的每一个建议,但什么都没用。

这是我使用的文档: https://firebase.google.com/docs/crashlytics/get-started?platform=android

我已经删除并清除了 Firebase 应用程序在线并尝试重新安装(3 次),但什么都没用。希望有人能帮我解决这个问题。

这是我的 gradle 文件(应用级别)

plugins {
id 'com.example.test'
id 'kotlin-android'
id 'kotlin-kapt'
id 'com.google.gms.google-services'
id 'com.google.firebase.crashlytics'
}

android {
compileSdkVersion 30
buildToolsVersion "30.0.3"

defaultConfig {
    applicationId "com.example.test"
    minSdkVersion 16
    targetSdkVersion 30
    versionCode 1
    versionName "1.0"
    //for support vector images in an imageview
    vectorDrawables.useSupportLibrary = true


    testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}

buildTypes {
    release {
        minifyEnabled false
        proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
    }
}
compileOptions {
    sourceCompatibility JavaVersion.VERSION_1_8
    targetCompatibility JavaVersion.VERSION_1_8
}
kotlinOptions {
    jvmTarget = '1.8'
}
buildFeatures {
    viewBinding true
}
}

dependencies {

implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
implementation 'androidx.core:core-ktx:1.5.0'
implementation 'androidx.appcompat:appcompat:1.2.0'
implementation 'com.google.android.material:material:1.3.0'
implementation 'androidx.constraintlayout:constraintlayout:2.0.4'
implementation 'com.google.android.material:material:1.3.0'
implementation 'androidx.recyclerview:recyclerview:1.2.0'
// cardView library
implementation 'androidx.cardview:cardview:1.0.0'
// Viewpager2
implementation 'androidx.viewpager2:viewpager2:1.0.0'
//tablayout
implementation 'com.google.android.material:material:1.4.0-beta01'
implementation 'androidx.legacy:legacy-support-v4:1.0.0'
implementation 'com.synnapps:carouselview:0.1.5'
implementation 'androidx.navigation:navigation-fragment-ktx:2.3.5'
implementation 'androidx.navigation:navigation-ui-ktx:2.3.5'
testImplementation 'junit:junit:4.+'
androidTestImplementation 'androidx.test.ext:junit:1.1.2'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0'

// firebase
implementation platform('com.google.firebase:firebase-bom:28.0.1')
implementation 'com.google.firebase:firebase-crashlytics-ktx'
implementation 'com.google.firebase:firebase-analytics-ktx'
 }

这是我的 build.gradle(包级别)

buildscript {
ext.kotlin_version = "1.4.32"
repositories {
    google()
    jcenter()
}
dependencies {
    classpath 'com.android.tools.build:gradle:4.2.1'
    classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
    // NOTE: Do not place your application dependencies here; they belong
    // in the individual module build.gradle files
    classpath 'com.google.gms:google-services:4.3.8'
    classpath 'com.google.firebase:firebase-crashlytics-gradle:2.6.1'
}
}
allprojects {
    repositories {
         google()
         jcenter()
     }
  }

 task clean(type: Delete) {
     delete rootProject.buildDir
  }

不,我确实尝试了那个主题中的所有解决方案,但没有任何效果。 - chrispsv
这并不改变你的问题是一个重复问题的事实,也没有提供最少的信息来重现这个问题。虽然这很抽象,但它也缺乏调试信息。发布一些错误消息并抱怨并不算是一个问题。 - Martin Zeitler
对不起,我刚刚添加了应该有用的文件(在我的沮丧中我完全忘记了)。 - chrispsv
4
在URL中显示:1:966637647957:android:9f830999a842bf19b5fcdc,这是您的应用程序ID。确保:1)此应用程序ID存在于您的项目中;2)如果不存在或应用程序ID现已更改,则意味着您正在使用较旧的google-services.json文件。在这种情况下,只需尝试下载一个新文件。同时,请确保在应用中启用了Crashlytics。 - Gerardo
非常感谢!替换google-services.json文件解决了我的问题。(我昨天已经尝试过一次,但那时没有起作用,今天早上就可以了,所以非常感谢!) :) - chrispsv
3个回答

15

我遇到了类似的错误。经过查看多个潜在解决方案甚至解决方法之后,我检查了尝试获取设置的URL,并发现我的App Id设置为旧的id。

使用来自Firebase控制台的最新google-services.json文件(将其添加到您的项目中)。

P.S.:在更新应用程序中的google-services.json后,请检查其他相关的Google / Firebase工具和服务。这个小问题还阻碍了我的Firebase事件。

P.P.S.:+1 对@Gerardo的答案以上。


2
即使使用了最新的 google-services.json,您是否仍然不断收到错误提示? - SarangD
8
对我来说,错误在于我没有在控制台中启用 Crashlytics。我的错。但即使如此,它仍然无法工作(Firebase 控制台中只有空白页面),直到我实际上强制让我的应用程序至少崩溃一次。只有在那之后,它才开始在控制台中显示崩溃信息... - qkx
3
你可以在文档中找到这个信息。你的应用程序需要在初始化时崩溃一次。这就是 Crashlytics 文档中的“入门”功能所帮助实现的。希望你的问题现在已经解决了。 - SarangD
1
我使用了两个包名来启用在同一手机上安装两种风味。这意味着我还必须在Firebase控制台中将Crashlytics启用到另一个包名。 - CaptainNemo

1

我遇到了同样的问题,检查了应用程序的所有ID,发现与Firebase相同,但当我转到Firebase上的Crashlytics选项卡时,发现我没有启用它,因此在启用后它可以正常工作。


-3
在Android 9.0及以上版本中,cleartextTrafficPermitted默认为false,这将阻止您的应用程序发送任何http请求。要解决此问题,您必须允许firebase-settings.crashlytics.com域名。
<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
    <base-config cleartextTrafficPermitted="false">
        <trust-anchors>
            <certificates src="system" />
        </trust-anchors>
    </base-config>
    <domain-config cleartextTrafficPermitted="true">
        <domain includeSubdomains="true">firebase-settings.crashlytics.com</domain>
    </domain-config>
</network-security-config>

我应该将这段代码添加到哪个文件中? - Niklas
不要这样做。这将使 Firebase 使用 http 而不是 https,如果你需要 http,那么你可能有其他需要修复的问题。 - undefined

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接