我正在使用以下代码来跟踪应用崩溃的时间:
val core = CrashlyticsCore
.Builder()
.listener {
Log.d("***", "Crash happened")
}
.build()
val crashlyticsKit = Crashlytics
.Builder()
.core(core)
.build()
// Initialize Fabric with the debug-location_inactive crashlytics.
Fabric.with(context, crashlyticsKit)
我正在用throw NullPointerException()
和Crashlytics.getInstance().crash()
进行测试。他们都没有呼叫监听器。当应用再次启动时,将在日志中:
I/CrashlyticsCore: Initializing Crashlytics 2.6.1.23
I/CrashlyticsInitProvider: CrashlyticsInitProvider initialization successful
D/FirebaseApp: com.google.firebase.crash.FirebaseCrash is not linked. Skipping initialization.
I/CrashlyticsCore: Crashlytics report upload complete: SOME-LETTERS-AND-NUMBERS
我在做什么错了?
编辑 我使用How to show a Dialog after crash by using Crashlytics?中的代码作为我的模板,但API似乎略有变化(在此答案中,它作为一个类实例化,但现在它是一个侦听器,请参见docs)< / p>
答案 0 :(得分:5)
默认情况下,Firebase Crashlytics使用内容提供程序黑客自动进行自身初始化({com.crashlytics.android.CrashlyticsInitProvider
被注入到合并的AndroidManifest
中)。
根据documentation自动初始化可以用meta-data
标志覆盖:
<manifest>
<application>
<meta-data
android:name="firebase_crashlytics_collection_enabled"
android:value="false" />
</application>
</manifest>
现在调用Fabric.with(context, crashlyticsKit)
实际上将初始化sdk并应正确触发侦听器。
答案 1 :(得分:1)
根据https://docs.fabric.io/javadocs/crashlytics/2.6.8/deprecated-list.html文档,我们必须使用CrashlyticsCore.Builder()。listener。
在项目gradle文件中,置于依赖项以下。
buildscript {
ext.kotlin_version = '1.3.21'
repositories {
google()
jcenter()
//TODO for fabric crash
maven {
url 'https://maven.fabric.io/public'
}
}
dependencies {
classpath 'com.android.tools.build:gradle:3.5.0-alpha07'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
//TODO for fabric crash
classpath 'com.google.gms:google-services:4.2.0'
classpath 'io.fabric.tools:gradle:1.26.1'
//TODO end
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
google()
jcenter()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
在app.gradle文件中的依赖项放在gradle下面:
//TODO fabric crash
implementation 'com.google.firebase:firebase-core:16.0.7'
implementation 'com.crashlytics.sdk.android:crashlytics:2.9.9'
//TODO end
在清单文件中,将此元数据标签放在应用程序标签下。
在MainActivity.Kt
package com.darshan.crahdemo
import android.os.Bundle
import android.util.Log
import androidx.appcompat.app.AppCompatActivity
import com.crashlytics.android.Crashlytics
import com.crashlytics.android.core.CrashlyticsCore
import io.fabric.sdk.android.Fabric
import kotlinx.android.synthetic.main.activity_main.tvCrash
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val core = CrashlyticsCore
.Builder()
.listener {
Log.d("****************", "Crash happened")
}
.build()
val crashlyticsKit = Crashlytics
.Builder()
.core(core)
.build()
Fabric.with(this, crashlyticsKit)
tvCrash.text = "Crash!"
tvCrash.setOnClickListener {
Crashlytics.getInstance().crash() // Force a crash
}
}
}
我的测试代码运行正常。我已附上日志的屏幕截图。