函数一览 LogCore
//在application中调用,初始化腾讯Bugly异常上报
public static void initBugly(Context mContext, String mainPackageName, boolean isDebug, String userid)
//在application中调用 日志选择1: 初始化 Xlog
public static void initXLog(boolean isOpenLog)
//在application中调用 日志选择2: 初始化 MoaLog
public static void initMoaLog(boolean isOpenLog)
引入说明
1. 腾讯Bugly:异常上报
1.1 官网
- 腾讯Bugly
腾讯Bugly,为移动开发者提供专业的异常上报,运营统计和内测分发解决方案,帮助开发者快速发现并解决异常,同时掌握产品运营动态,及时跟进用户反馈
- 异常上报
- 内测分发
- 应用升级 & 热更新
- 应用统计
- [异常上报: Bugly Android SDK 使用指南] (https://bugly.qq.com/docs/user-guide/instruction-manual-android/?v=20161219153020)
1.2 异常上报-接入
- Module.bulid.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
}
- 需要权限
<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" />
- 混淆过滤
-dontwarn com.tencent.bugly.**
-keep public class com.tencent.bugly.**{*;}
- 初始化 :Application类onCreate()
CrashReport.initCrashReport(getApplicationContext(), "注册时申请的APPID", false);
1.3 使用
- 主app的Application类onCreate()
CrashReportUtils.initBugly(getmContext(),getmContext().getPackageName(), test.com.yu.BuildConfig.DEBUG, getLoginServerId());
2. MOALOG的引入
实现了日志打印功能,调用MoaLogCore.i
3. Xlog引入说明
官网
3.1 异常上报-接入
- Module.bulid.gradle中
dependencies {
compile 'com.elvishew:xlog:1.3.0'
}
- 初始化 :Application类onCreate()
LogConfiguration config = new LogConfiguration.Builder()
.logLevel(BuildConfig.DEBUG ? LogLevel.ALL // 指定日志级别,低于该级别的日志将不会被打印,默认为 LogLevel.ALL
: LogLevel.NONE)
.tag("MY_TAG") // 指定 TAG,默认为 "X-LOG"
.t() // 允许打印线程信息,默认禁止
.st(2) // 允许打印深度为2的调用栈信息,默认禁止
.b() // 允许打印日志边框,默认禁止
.jsonFormatter(new MyJsonFormatter()) // 指定 JSON 格式化器,默认为 DefaultJsonFormatter
.xmlFormatter(new MyXmlFormatter()) // 指定 XML 格式化器,默认为 DefaultXmlFormatter
.throwableFormatter(new MyThrowableFormatter()) // 指定可抛出异常格式化器,默认为 DefaultThrowableFormatter
.threadFormatter(new MyThreadFormatter()) // 指定线程信息格式化器,默认为 DefaultThreadFormatter
.stackTraceFormatter(new MyStackTraceFormatter()) // 指定调用栈信息格式化器,默认为 DefaultStackTraceFormatter
.borderFormatter(new MyBoardFormatter()) // 指定边框格式化器,默认为 DefaultBorderFormatter
.addObjectFormatter(AnyClass.class, // 为指定类添加格式化器
new AnyClassObjectFormatter()) // 默认使用 Object.toString()
.addInterceptor(new BlacklistTagsFilterInterceptor( // 添加黑名单 TAG 过滤器
"blacklist1", "blacklist2", "blacklist3"))
.addInterceptor(new MyInterceptor()) // 添加一个日志拦截器
.build();
Printer androidPrinter = new AndroidPrinter(); // 通过 android.util.Log 打印日志的打印器
Printer consolePrinter = new ConsolePrinter(); // 通过 System.out 打印日志到控制台的打印器
Printer filePrinter = new FilePrinter // 打印日志到文件的打印器
.Builder("/sdcard/xlog/") // 指定保存日志文件的路径
.fileNameGenerator(new DateFileNameGenerator()) // 指定日志文件名生成器,默认为 ChangelessFileNameGenerator("log")
.backupStrategy(new NeverBackupStrategy() // 指定日志文件备份策略,默认为 FileSizeBackupStrategy(1024 * 1024)
.logFlattener(new MyFlattener()) // 指定日志平铺器,默认为 DefaultFlattener
.build();
XLog.init( // 初始化 XLog
config, // 指定日志配置,如果不指定,会默认使用 new LogConfiguration.Builder().build()
androidPrinter, // 添加任意多的打印器。如果没有添加任何打印器,会默认使用 AndroidPrinter(Android)/ConsolePrinter(java)
consolePrinter,
filePrinter);