iOS Crash处理方法(三):获取用户的Crash文件

当我们把APP的安装包发给用户,或者APP已经上线了,用户安装后使用出现了Crash,而且用户距离你很远很远,远到你无法去看出现Crash复现情况的时候,应该怎么去分析这个Crash的原因呢?
这里有个最简单的方法,就是要用户把Crash文件发给你!当然如果他不肯,那就没办法啦,等待Itunes Contect、Xcode crash log 或者 腾讯Bugly这些第三方吧,当然也可以自己做一个Crash的上传,自己代码收集Crash的方法在这里,所以这一篇的必要条件就是在用户很开心地把Crash文件发送给你,于是你就很愉快地分析Crash的整个过程。

1、用户使用PC提取手机的Crash log文件

目前很多第三方软件,如ITOOS,不过我这里只说明 iTunes 的使用方法(毕竟Mac一买回来就有 iTunes 了嘛,至于windows………下一个吧),首先用户需要把手机连接电脑,打开 iTunes 把手机和电脑进行同步操作,这时候iTunes 会将APP的崩溃日志保存在电脑上。


屏幕快照 2017-10-12 18.10.58.png

根据电脑操作系统的不同,崩溃日志将保存在以下位置:

  • Mac OS X:~/Library/Logs/CrashReporter/MobileDevice/
  • Windows XP:C:\Documents and Settings\Application Data\Apple computer\Logs\CrashReporter
  • Windows 7/Vista: C:\Users\电脑登陆的用户名\AppData\Roaming\Apple Computer\Logs\CrashReporter\MobileDevice

这里面会有用户手机的数据文件夹


屏幕快照 2017-10-12 18.15.42.png

你可以让用户把整个文件夹(****的iPhone)打包发给你,我们需要的是里面的.crash 文件,如果你的工程名是TempPro,那么你的APP的crash文件名字就是 TempPro-2017-10-10-103518.crash。

2、符号化Crash的准备工作

完成第一步,我们就拿到了.crash文件了,可以先打开.crash文件看一下


屏幕快照 2017-10-12 18.21.23.png

除了比较明朗的Crash 类型也没什么信息,如何知道是哪里的代码出现了问题了呢?再往下看,是不是有一堆数字,这个是不是跟我们平常拿到的Exception信息差不多一个样,不同的是这里全是数字(我是看不懂了),这时候就要使用symbolicatecrash工具对其进行符号化。

(1)第一步在合适的地方(例如桌面)创建一个文件夹 MyCrash
(2)在mac找下symbolicatecrash(Xcode自带的工具)

打开终端执行下面的命令

find /Applications/Xcode.app -name symbolicatecrash -type f

执行结束会有一个路径出现,那就symbolicatecrash工具的路径,你可以用Finder 打开这个路径,然后把 symbolicatecrash 工具复制粘贴到 我们创建 的 MyCrash 文件夹里面

(3)获取.app.dSYM文件(就是你的APP打包时生成的)

具体获取方法,获取方法:打开Xcode -> Window -> Organrizer -> Archives -> 你的项目名(TempPro) -> 右键"Show in Finder" -> 右键TempPro.xcarchive 文件 -> 显示包内容 -> dSYMs -> TempPro.app.dSYM
把TempPro.app.dSYM文件也拷贝到 ** MyCrash
** 文件夹下面

(4)把.crash文件拷贝到 MyCrash 文件夹下
屏幕快照 2017-10-12 18.53.09.png
3、开始符号化Crash

打开终端,跳转到 MyCrash 文件夹

屏幕快照 2017-10-12 18.56.29.png

执行symbolicatecrash命令:

./symbolicatecrash ./TempPro-2017-10-10-103518.crash ./TempPro.app.dSYM > newTempPro.crash

命令说明:

./symbolicatecrash  要符号化的文件.crash路径  你的工程app.dSYM文件路径  >  最终符号化后的文件.crash

(文件可以直接拖拽到终端,我就懒得输入路径…)

执行结束之后, MyCrash 文件夹会出现一个新文件newTempPro.crash

屏幕快照 2017-10-12 19.03.07.png

打开newTempPro.crash(我的工程名是musicController

屏幕快照 2017-10-12 19.05.36.png

之前.crash的那一堆数字被符号化成我们熟悉的Exception信息,用我的工程为示例,直接看 1 ~ 4 行信息,就可以看到代码Crash的位置 (Socket.m:57),不过要找到真正Crash的原因,还需要结合其他信息才能看出来,比如0行,我这里是因为OC对象已经被释放,变成了野指针,我还用这个对象执行方法(objc_msgSend),所以发生了Crash(这个BUG我也郁闷了好久,结果是因为OC对象在CF回调方法中没有执行CFRetain,结果在其他地方这个OC对象被释放掉,额……就这么浪蛋)。

注:
第一次运行symbolicatecrash可能会报错,错误内容大概是这样

Error: "DEVELOPER_DIR" is not defined at ./symbolicate

解决方法:命令行直接运行下面这行命令

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