1. 概述
这篇文章主要记录下自己在开发过程中是如何集成腾讯的Bugly,以及如何在项目中用它来统计收集bug,然后可以在自己后台的bugly管理系统中查看,具体的大家可以移步 腾讯Bugly官方文档,那么解析来我们就一起来看下,我们是如何一步一步集成腾讯Bugly,又是如何一步一步把它用到我们的项目中的。
2. 具体实现
2.1>:首先去腾讯Bugly官网申请账号,这里最好是公司的账号,顺便说一下,凡是涉及到需要集成第三方的一些东西,一律使用公司申请的账号。
2.2>:填写完之后就去下载它的 SDK
2.3>:或者第二步也可以不用去下载SDK,直接按照我下边配置也是可以的:
项目的bulid.gradle
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.3.1'
classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
// 腾讯bugly
classpath 'com.tencent.bugly:symtabfileuploader:2.1.0'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
jcenter()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
app的build.gradle
apply plugin: 'com.android.application'
apply plugin: 'com.neenbedankt.android-apt'
//腾讯bug管理插件
apply plugin: 'bugly'
android {
compileSdkVersion 25
buildToolsVersion "25.0.2"
defaultConfig {
applicationId "cn.novate.ykh"
minSdkVersion 16
targetSdkVersion 23
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
/** 腾讯bugly */
/*ndk {
// 设置支持的 SO 库构架
abiFilters 'armeabi', 'x86'// 'armeabi-v7a', 'arm64-v8a', 'x86', 'x86_64', 'mips', 'mips64'
}*/
ndk {
abiFilters "armeabi", "armeabi-v7a", "x86", "mips"
}
// 64k
multiDexEnabled true
}
}
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
exclude group: 'com.android.support', module: 'support-annotations'
})
compile 'com.android.support:appcompat-v7:23.1.1'
compile 'com.android.support.constraint:constraint-layout:1.0.2'
testCompile 'junit:junit:4.12'
//腾讯bug管理平台
compile 'com.tencent.bugly:crashreport:2.6.0'
compile 'com.tencent.bugly:nativecrashreport:3.3.0'
}
2.3>:在BaseApplication的onCreate中初始化就ok,下边会涉及到appId,这里记得要把我们刚才创建应用的appId找到,然后把下边的替换为我们自己应用的appId即可;
/**
* 初始化腾讯bug管理平台
*/
private void initBugly() {
/* Bugly SDK初始化
* 参数1:上下文对象
* 参数2:APPID,平台注册时得到,注意替换成你的appId
* 参数3:是否开启调试模式,调试模式下会输出'CrashReport'tag的日志
* 注意:如果您之前使用过Bugly SDK,请将以下这句注释掉。
*/
CrashReport.UserStrategy strategy = new CrashReport.UserStrategy(getApplicationContext());
strategy.setAppVersion(AppUtils.getAppVersionName());
strategy.setAppPackageName(AppUtils.getAppPackageName());
strategy.setAppReportDelay(20000); //Bugly会在启动20s后联网同步数据
/* 第三个参数为SDK调试模式开关,调试模式的行为特性如下:
输出详细的Bugly SDK的Log;
每一条Crash都会被立即上报;
自定义日志将会在Logcat中输出。
建议在测试阶段建议设置成true,发布时设置为false。*/
CrashReport.initCrashReport(getApplicationContext(), "4ae3b64456", true ,strategy);
//Bugly.init(getApplicationContext(), "1374455732", false);
}
以上就已经集成完Bugly,为了验证我们是否已经集成成功,下边我们就来做一个测试,最好写一个点击事件,一点击就让它崩溃,比如我们让点击一个按钮,然后弹出 2/0 的提示 ,下边我们就来验证下
测试Bugly是否集成成功:
case R.id.rl_me_set:
showToast("测试bugly结果" + 2/0);
CrashReport.testJavaCrash();
break;
注意:
在测试崩溃情况的时候,需要在每一个崩溃代码下边添加CrashReport.testJavaCrash();用于测试,只要一点击,崩溃后,然后打开我们Bugly的管理平台,如果在 "崩溃页面" 或者 "异常分析页面" 出现了我们刚才的bug,就说明我们集成成功,然后就需要把这个测试的代码注释即可。