iOS 中如何将部分 Log 保存并上传?
1. 将全部的 log 写入本地文件
|
|
这个方法主要是调用freopen
这个方法来写入, 其中 stdout 和 stderr 囊括了 iOS 大部分的异常输出。
2. 根据 Bool 值控制 log 输出
用户在使用 app 遇到各种各样的问题,当自己以及测试团队不好定位原因的时候,能将用户把关键点的 log 发送过来是最好的分析方法了。但是如何将 app 运行过程中的 log 截取一部分保存呢?像开关一样能够控制 log 的读写呢?通过阅读 MQTTLog 源码发现获得的灵感。
首先对 NSLog 进行下宏替换,项目中统一使用 SLOG 来进行输出
|
|
从宏定义可以看出,reportLoggerIsOpen 是控制 Log 输出的开关,对于reportLoggerIsOpen的定义,在 h 文件中先 extern 声明这个变量,然后再 m 文件中去实现。12345.h 文件#import <Foundation/Foundation.h>extern BOOL reportLoggerIsOpen;
|
|
通过setLogOpen
这个方法,就能够收放自如的控制日志写入了。比如你需要抓取登录模块的日志,那么就在登录前传入 true,登录完毕后,传入 false,即可只保留登录模块的日志了。