iOS集成Bugly异常上报

腾讯Bugly,为移动开发者提供专业的异常上报和运营统计,帮助开发者快速发现并解决异常,同时掌握产品运营动态,及时跟进用户反馈。

Bugly是一套强大的异常上报SDK,包含异常上报、运营统计、内测分发、热修复等功能,实在是定位、修复生产上bug的必备良品😁。Bugly

  • 集成

建议使用CocoaPods集成Bugly,如果不会使用pod建议问一下度娘。
Pods代码:pod 'Bugly'

  • 初始化

初始化需要一个AppId,在Bugly上新建一个应用就可以获取对应的AppId了;初始化Bugly也很简单:

 - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    // 改成你的AppId
    [Bugly startWithAppId:Bugly_ID];
    return YES;
}

到此,你就可以正式使用Bugly啦!!!
但是我们就这样使用Bugly是不是太可惜了,我们来看看Bugly还有什么功能;查看头文件,会发现Bugly有三个类暴露出来,分别是Bugly、BuglyConfig和BuglyLog。

1.自定义初始化

BuglyConfig类主要用于个性话配置Bugly类,由一些属性和BuglyDelegate代理组成。
属性:BuglyConfig大部分属性有设有默认值,一般不用更改,但是关于卡顿监控的属性确是默认关闭的:

/**
 *  卡顿监控开关,默认关闭
 */
@property (nonatomic) BOOL blockMonitorEnable;
/**
 *  卡顿监控判断间隔,单位为秒
 */
@property (nonatomic) NSTimeInterval blockMonitorTimeout;

如果需要上报卡顿,只需要将blockMonitorEnable设为true,给blockMonitorTimeout设置一个合理的值即可;
代理:BuglyConfig可以设置一个代理,来自定义上传崩溃的附属信息;

@protocol BuglyDelegate <NSObject>

 @optional
/**
 *  发生异常时回调
  *  @param exception 异常信息
  *  @return 返回需上报记录,随异常上报一起上报
 */
 - (NSString * BLY_NULLABLE)attachmentForException:(NSException * BLY_NULLABLE)exception;
@end

这个时候我们的初始化就可以写成:

  - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

    // 启动Bugly
    [Bugly startWithAppId:Bugly_ID config:^{
        BuglyConfig *config = [[BuglyConfig alloc] init];
        config.blockMonitorEnable = YES;
        config.blockMonitorTimeout = 2;
        config.consolelogEnable = YES;
        config.delegate = self;
        return config;
    }()];
    return YES;
 }

 - (NSString *)attachmentForException:(NSException *)exception {
    return @"Do you want to do...";
 }

2.上传打印日志

BuglyLog类主要用于打印日志,有6种级别:

typedef NS_ENUM(NSUInteger, BuglyLogLevel) {
    BuglyLogLevelSilent  = 0,
    BuglyLogLevelError   = 1,
    BuglyLogLevelWarn    = 2,
    BuglyLogLevelInfo    = 3,
    BuglyLogLevelDebug   = 4,
    BuglyLogLevelVerbose = 5,
};

BuglyLog除了控制台打印,还有一个重要功能就是上报打印内容,内容将在崩溃时一同被上报;但是这个功能是默认不上报的,需要配置BuglyConfig的reportLogLevel属性;如config.reportLogLevel = BuglyLogLevelWarn,将会上报BuglyLogLevelWarn和BuglyLogLevelError级别的打印日志。

3. 自定义上报异常

我们再回到Bugly类,除了初始化Bugly的方法外,还有一些其他的方法:

  • 关键值上报
/**
 *  设置关键数据,随崩溃信息上报
 */
 + (void)setUserValue:(nonnull NSString *)value
              forKey:(nonnull NSString *)key;
  • 自定义上报错误
/**
 *  上报自定义异常
  *  @param exception 异常信息
 */
 + (void)reportException:(nonnull NSException *)exception;
/**
 *  上报错误
  *  @param error 错误信息
 */
 + (void)reportError:(NSError *)error;

这个功能可以说十分有用,可以让我们定位到一些没有引起崩溃的问题,我们可以在一些关键操作和网络请求处上报一些异常信息,以此优化我们的程序;这些错误信息在错误分析可以被查看到。

  • 上传符号表

当我们到Bugly查看崩溃信息的时候,会发现堆栈信息打印了一堆地址,特别是信号量出错的情况下,很难有效的定位到崩溃原因,这个时候就需要符号表了。

  • 什么是符号表
    符号表是内存地址与函数名、文件名、行号的映射表。符号表元素如下所示:
    <起始地址> <结束地址> <函数> [<文件名:行号>]
  • 为什么要配置符号表?
    为了能快速并准确地定位用户APP发生Crash的代码位置,Bugly使用符号表对APP发生Crash的程序堆栈进行解析和还原。

符号表可以在我们的工程中配置sh脚本快速上传,手动上传的话麻烦一点,详细请看官方文档.

  • 不使用第三方自己收集异常日志?

看到Bugly只暴露了三个类就完成异常日志收集工作,是不是心痒痒想自己写一个呢?我劝你还是别撒了,有个这么强大而且免费的SDK,折腾自己干嘛!!!好吧,也不是不能实现,研究一下NSException就会有些收获;细心的你可能发现了一条有用的API:

typedef void NSUncaughtExceptionHandler(NSException *exception);
FOUNDATION_EXPORT NSUncaughtExceptionHandler * _Nullable NSGetUncaughtExceptionHandler(void);
FOUNDATION_EXPORT void NSSetUncaughtExceptionHandler(NSUncaughtExceptionHandler * _Nullable);

看到这里你可能想说,这不是就可以搞了吗?但是NSSetUncaughtExceptionHandler这个函数在信号量出错的情况下是不会回调的,他不能捕获信号量异常,如果你还不想放弃可以看一下这篇博文

推荐@chenfanfang关于NSException的文章:
iOS被开发者遗忘在角落的NSException-其实它很强大
iOS runtime实用篇--和常见崩溃say good-bye!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容

  • 在开发APP的过程中,崩溃等异常总是让我们不堪其烦,不过开发阶段的崩溃等问题,都是小事,可以进行处理,但是一旦发布...
    IUVO阅读 14,574评论 3 27
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,649评论 18 139
  • 本文就捕获iOS Crash、Crash日志组成、Crash日志符号化、异常信息解读、常见的Crash五部分介绍。...
    xukuangbo_阅读 1,579评论 0 0
  • [这是第14篇] 序: iOS Crash问题是iOS开发中难以忽视的存在,本文就捕获iOS Crash、Cras...
    南华coder阅读 9,875评论 21 116
  • 2017年的第一次晚睡,献给了我该死的强迫症。 今晚吃完晚餐后,散步后回家,和闺蜜说我想收拾一下房间。她说那就开始...
    夏天说早安阅读 363评论 4 1