1、集成SDK
在module的build.gradle文件中添加依赖和属性配置
dependencies {
compile 'com.tencent.bugly:crashreport:latest.release' //其中latest.release指代最新Bugly SDK版本号,也可以指定明确的版本号,例如2.2.0
}
2、参数配置
3、混淆
-dontwarn com.tencent.bugly.**
-keep public class com.tencent.bugly.**{*;}
4、初始化
在Application中进行初始化
CrashReport.initCrashReport(getApplicationContext(), "注册时申请的APPID", false);
// 为了保证运营数据的准确性,建议不要在异步线程初始化Bugly
/**
*第三个参数为SDK调试模式开关,调试模式的行为特性如下:
输出详细的Bugly SDK的Log;
每一条Crash都会被立即上报;
自定义日志将会在Logcat中输出。
建议在测试阶段建议设置成true,发布时设置为false。
*
*
*/
5、如果类中使用了MultiDex解决65535问题
如果使用了MultiDex,建议通过Gradle的“multiDexKeepFile
”配置等方式把Bugly的类放到主Dex,另外建议在Application
类的"attachBaseContext
"方法中主动加载非主dex:
/**
* 如果使用了MultiDex,建议通过Gradle的“multiDexKeepFile”配置等方式把Bugly的类放到主Dex,
* 另外建议在Application类的"attachBaseContext"方法中主动加载非主dex
*
* @param base
*/
@Override
protected void attachBaseContext(Context base) {
super.attachBaseContext(base);
MultiDex.install(this);
}
6、增加上报进程控制
如果App使用了多进程且各个进程都会初始化Bugly(例如在Application类onCreate()中初始化Bugly),那么每个进程下的Bugly都会进行数据上报,造成不必要的资源浪费。
因此,为了节省流量、内存等资源,建议初始化的时候对上报进程进行控制,只在主进程下上报数据:判断是否是主进程(通过进程名是否为包名来判断),并在初始化Bugly时增加一个上报进程的策略配置。
Context context = getApplicationContext();
// 获取当前包名
String packageName = context.getPackageName();
// 获取当前进程名
String processName = getProcessName(android.os.Process.myPid());
// 设置是否为上报进程
UserStrategy strategy = new UserStrategy(context);
strategy.setUploadProcess(processName == null || processName.equals(packageName));
// 初始化Bugly
CrashReport.initCrashReport(context, "注册时申请的APPID", isDebug, strategy);
// 如果通过“AndroidManifest.xml”来配置APP信息,初始化方法如下
// CrashReport.initCrashReport(context, strategy);
其中获取进程名的方法“getProcessName”有多种实现方法,推荐方法如下:
/**
* 获取进程号对应的进程名
*
* @param pid 进程号
* @return 进程名
*/
private static String getProcessName(int pid) {
BufferedReader reader = null;
try {
reader = new BufferedReader(new FileReader("/proc/" + pid + "/cmdline"));
String processName = reader.readLine();
if (!TextUtils.isEmpty(processName)) {
processName = processName.trim();
}
return processName;
} catch (Throwable throwable) {
throwable.printStackTrace();
} finally {
try {
if (reader != null) {
reader.close();
}
} catch (IOException exception) {
exception.printStackTrace();
}
}
return null;
}
1、配置build.gradle
//注释掉原有bugly的仓库
//compile 'com.tencent.bugly:crashreport:latest.release'
compile 'com.tencent.bugly:crashreport_upgrade:latest.release'
//compile 'com.tencent.bugly:nativecrashreport:latest.release'//没使用NDK开发不用添加
2、权限配置和异常上报一样(略)
3、Activity配置
4、配置FileProvider
如果和调用相机的provider冲突,可以通过继承FileProvider类来解决合并冲突的问题
/**
* Created by zhaoliang on 2018/9/20
*创建一个继承FileProvider 的类
*/
public class BuglyFileProvider extends FileProvider {
}
//在manifest.xml文件中配置
5、SDK初始化
//注意:如果您之前使用过Bugly SDK,请将以下这句注释掉。
//CrashReport.initCrashReport(getApplicationContext(), "注册时申请的APPID", false);
//统一初始化方法:
Bugly.init(getApplicationContext(), "注册时申请的APPID", false);
6、线上操作发布新升级
请参考官网介绍:https://bugly.qq.com/docs/user-guide/instruction-manual-android-upgrade/?v=20180913155123