iOS崩溃时收集崩溃信息

作者: 朱思明 | 来源:发表于2017-02-03 11:49 被阅读62次

    背景

    1.在App上线时我们没有办法log手机的奔溃日志,现在网上有很多第三方收集奔溃日志的方法,常用的例如Crashlytics
    2.但我们也需要知道如何使用系统框架收集crash日志

    一、在App崩溃时收集崩溃信息

    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { 
        // Override point for customization after application launch.
        // 1.添加Crash崩溃函数监听
        NSSetUncaughtExceptionHandler (&UncaughtExceptionHandler);
        return YES;
    }
    
    // 当程序Crash时掉用此函数 
    void UncaughtExceptionHandler(NSException *exception) {
        // 1.异常类型
        NSString *name = [exception name];
        // 2.非常重要,就是崩溃的原因
        NSString *reason = [exception reason];
        // 3.得到当前调用栈信息
        NSArray *logArray = [exception callStackSymbols];
        // 4.崩溃日志
        NSString *crashLogInfo = [NSString stringWithFormat:@"exception type : %@ \n crash reason : %@ \n call stack info : %@", name, reason, logArray];
        // 5.可以缓存写入到本地,下次程序开启时发送的远端服务器
        // 再次我设置崩溃信息发送至邮箱
        NSString *urlStr = [NSString stringWithFormat:@"mailto://siming_zhu@163.com?subject=bug报告&body=感谢您的配合!,错误详情:%@", crashLogInfo];
        NSURL *url = [NSURL URLWithString:[urlStr stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]];
        [[UIApplication sharedApplication] openURL:url];
    }
    

    更多分享:

    Github:https://github.com/zhusiming/
    GitBook:https://zhusiming.gitbooks.io/smbook/

    相关文章

      网友评论

        本文标题:iOS崩溃时收集崩溃信息

        本文链接:https://www.haomeiwen.com/subject/fwkdittx.html