做开发的程序员总是避免不了程序出现异常崩溃,现在就介绍一款bug管理的工具。腾讯Bugly,为移动开发者提供专业的异常上报和运营统计,帮助开发者快速发现并解决异常,同时掌握产品运营动态,及时跟进用户反馈。

把自己的安卓项目关联至腾讯Bugly中,可以实时的看见自己的程序和用户之间的互动情况,以及崩溃的原因。

 

2.点击新建产品按钮!

android 33 配置_bugly使用

3.在我的产品界面中输入必填的内容。

4.在我的产品列表中找到你的App,点击设置,可以看到App ID 和App Key!

android 33 配置_bugly配置_02

5.现在到Studio中配置关联:

自动集成(推荐)

Bugly支持JCenter仓库(http://jcenter.bintray.com/com/tencent/bugly/)和Maven Central仓库(https://repo1.maven.org/maven2/com/tencent/bugly/)。为了实现更加灵活的配置,Bugly SDK(2.1.5及以上版本)和NDK(SO库)目前已经分开成两个独立的仓库:

SDK:com.tencent.bugly:crashreport
NDK:com.tencent.bugly:nativecrashreport
其中,集成Bugly NDK时,需要同时集成Bugly SDK。

集成SDK
在Module的build.gradle文件中添加依赖和属性配置:

dependencies {
    compile 'com.tencent.bugly:crashreport:latest.release' //其中latest.release指代最新Bugly SDK版本号,也可以指定明确的版本号,例如2.2.0
}

同时集成SDK和NDK
在Module的build.gradle文件中添加依赖和属性配置:

android {
    defaultConfig {
        ndk {
            // 设置支持的SO库架构
            abiFilters 'armeabi' //, 'x86', 'armeabi-v7a', 'x86_64', 'arm64-v8a'
        }
    }
}
dependencies {
    compile 'com.tencent.bugly:crashreport:latest.release' //其中latest.release指代最新Bugly SDK版本号,也可以指定明确的版本号,例如2.1.9
    compile 'com.tencent.bugly:nativecrashreport:latest.release' //其中latest.release指代最新Bugly NDK版本号,也可以指定明确的版本号,例如3.0
}

同时集成Bugly SDK和NDK的配置如下图所示,后续更新Bugly SDK和NDK时,只需变更配置脚本中的版本号即可。

android 33 配置_bugly_03

注意:自动集成时会自动包含Bugly SO库,建议在Module的build.gradle文件中使用NDK的“abiFilter”配置,设置支持的SO库架构。

如果在添加“abiFilter”之后Android Studio出现以下提示:

NDK integration is deprecated in the current plugin. Consider trying the new experimental plugin.

则在项目根目录的gradle.properties文件中添加:

android.useDeprecatedNdk=true

手动集成

如果您不采用上述自动导入方式,也可以手动集成Bugly SDK。

 

如果您的工程有Native代码(C/C++)或者集成了其他第三方SO库,建议下载Bugly的NDK动态库。
Bugly NDK包含多个架构的SO库:

armeabi
armeabi-v7a
arm64-v8a
x86
x86_64
在集成Bugly SO库时,请注意只保留支持的架构SO库。

Eclipse工程

将Bugly库文件复制到工程的libs目录下;

Refresh一下工程;

添加工程依赖:鼠标右键点击Bugly的JAR文件,添加到编译路径中。

android 33 配置_bugly_04

Android Studio工程

将Bugly库文件复制到工程的libs目录下;
如果集成Bugly NDK,则在Module的buid.gradle文件中添加SO库目录配置:

android {
    sourceSets {
        main.jniLibs.srcDirs = ['libs']
    }
}

点击Sync,同步配置。

android 33 配置_bugly使用_05

为了使APP Crash堆栈的可读性更高,建议您配置符号表文件,更准确地定位问题:

纯Java代码的工程:只需要配置混淆后生成的Mapping文件即可;
含有Native代码的工程:建议配置符号表工具从Debug SO中提取的Symbol符号表文件。
Bugly支持手动和自动配置两种方式,具体的配置方法请参考:《Bugly Android符号表配置》(https://bugly.qq.com/docs/user-guide/symbol-configuration-android/

参数配置
在AndroidManifest.xml中添加权限:

<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.READ_LOGS" />

请避免混淆Bugly,在Proguard混淆文件中增加以下配置:

-dontwarn com.tencent.bugly.**
-keep public class com.tencent.bugly.**{*;}

最简单的初始化

获取APP ID并将以下代码复制到项目Application类onCreate()中,Bugly会为自动检测环境并完成配置:

CrashReport.initCrashReport(getApplicationContext(), "注册时申请的APPID", false);//这个值就是刚才图片中的App ID填入