Android集成Firebase Crashlytics,及启动原理分析

Firebase Crashlytics用于崩溃日志上报,通常是需要科学上网的,在集成前务必确保自己能科学上网!!!

第一步:添加插件依赖
  • 在根目录的build.gradle文件添见插件依赖
groovy 复制代码
buildscript {
    dependencies {
        classpath 'com.google.firebase:firebase-crashlytics-gradle:2.9.5'
        classpath 'com.google.gms:google-services:4.3.14'
    }
}
  • 在app模块的build.gradle文件里面添加插件
groovy 复制代码
plugins {
    //*************firebase集成*************
    id 'com.google.gms.google-services'
    id 'com.google.firebase.crashlytics'
    //*************firebase集成*************
}
第二步:添加依赖包
  • 在app模块的build.gradle文件里面添加插件
groovy 复制代码
implementation(platform("com.google.firebase:firebase-bom:31.0.1"))
implementation('com.google.firebase:firebase-crashlytics')
第三步:在Android Studio中配置firebase

这一步需要登录Google账号,也就是你的Firebase账号,登录之后会显示用户头像,注意这里需要科学上网 我这里是使用端口代理才登录成功

第四步:触发异常

模拟两种场景,主线程和子线程,主动抛出异常、主动记录异常、和运行过程中的异常情形,发现均没有上报!!! 按照文档所说会自动采集崩溃日志,但是我发现在firebase后端并没有自动收集成功,通过查看源码发现自己项目中依赖的三方库使用了线程异常捕获,导致没有上报

java 复制代码
//此方法可以收集线程中的异常,我依赖的三方库就是调用了这个方法
Thread.setDefaultUncaughtExceptionHandler { thread, throwable ->
}

这个方法只是保存了一个静态变量,意味着如果别的地方设置了这个值而原来的值没有缓存,原来设置的效果就不会起作用

Firebase Crashlytics原理分析:

Crashlytics的SDK里面注册了一个Provider 在这个Provider初始化的时候会调用FirebaseApp.initializeApp,下边截图是代码的调用链路,不想看的话可以看小结: 小结:Firebase Crashlytics在APP启动的时候也,就是在自己的Provider中会调用Thread.setDefaultUncaughtExceptionHandler方法设置一个异常捕获,Provider的声明周期在Application的onCreate之前,所以可以在onCreate里面获取之前设置的异常捕获,然后重新设置:

java 复制代码
override fun onCreate() {
    super.onCreate()
    //取出firebase crash中设置的handler
    val firebaseUncaughtExceptionHandler = Thread.getDefaultUncaughtExceptionHandler()
    //init方法会重新设置UncaughtExceptionHandler
    init()
    //取出init中设置的handler
    val initUncaughtExceptionHandler = Thread.getDefaultUncaughtExceptionHandler()
    //重新设置handler
    Thread.setDefaultUncaughtExceptionHandler { thread, throwable ->
        initUncaughtExceptionHandler?.uncaughtException(thread, throwable)
        firebaseUncaughtExceptionHandler?.uncaughtException(thread, throwable)
    }
}

上述代码插入后,firebase终于上报成功了,可以在工具栏App Quality Insights里面查看

使用链接:developer.android.com/studio/debu...

相关推荐
豆豆43 分钟前
为什么用PageAdmin CMS建设网站?
服务器·开发语言·前端·php·软件构建
twins35202 小时前
解决Vue应用中遇到路由刷新后出现 404 错误
前端·javascript·vue.js
qiyi.sky2 小时前
JavaWeb——Vue组件库Element(3/6):常见组件:Dialog对话框、Form表单(介绍、使用、实际效果)
前端·javascript·vue.js
煸橙干儿~~2 小时前
分析JS Crash(进程崩溃)
java·前端·javascript
安冬的码畜日常2 小时前
【D3.js in Action 3 精译_027】3.4 让 D3 数据适应屏幕(下)—— D3 分段比例尺的用法
前端·javascript·信息可视化·数据可视化·d3.js·d3比例尺·分段比例尺
l1x1n03 小时前
No.3 笔记 | Web安全基础:Web1.0 - 3.0 发展史
前端·http·html
昨天;明天。今天。3 小时前
案例-任务清单
前端·javascript·css
zqx_74 小时前
随记 前端框架React的初步认识
前端·react.js·前端框架
惜.己4 小时前
javaScript基础(8个案例+代码+效果图)
开发语言·前端·javascript·vscode·css3·html5
什么鬼昵称5 小时前
Pikachu-csrf-CSRF(get)
前端·csrf