Android如何集成腾讯Bugly

1. 概述

这篇文章主要记录下自己在开发过程中是如何集成腾讯的Bugly,以及如何在项目中用它来统计收集bug,然后可以在自己后台的bugly管理系统中查看,具体的大家可以移步 腾讯Bugly官方文档,那么解析来我们就一起来看下,我们是如何一步一步集成腾讯Bugly,又是如何一步一步把它用到我们的项目中的。

2. 具体实现

2.1>:首先去腾讯Bugly官网申请账号,这里最好是公司的账号,顺便说一下,凡是涉及到需要集成第三方的一些东西,一律使用公司申请的账号。

集成Bugly需要填写的东西

2.2>:填写完之后就去下载它的 SDK

下载Bugly 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,就说明我们集成成功,然后就需要把这个测试的代码注释即可。

    原文作者:世道无情
    原文地址: https://www.jianshu.com/p/0aab4b2140fe
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞