之前上架被苹果拒绝,然后发了个crash log回来,折腾了好一阵,最后参考了几个博客解决了,以下是引用这个的(https://www.jianshu.com/p/3caccc287346 还有 https://www.jianshu.com/p/5728e2cd4d86)。先拿过来做个记录。
基本参考这2个就差不多了,后面有时间再整理一下。
拿到crash log之后我们激动的点开了,但是发现里面居然一脸懵逼,尤其是堆栈信息,如下:
Snip20170531_497.png
很是蛋疼,所以我们就开启了一段解析这些地址之旅。以下是一些概念和专业术语,希望大家好好了解下:
什么是dSYM文件
Xcode编译项目后,我们会看到一个同名的 dSYM 文件,dSYM 是保存 16 进制函数地址映射信息的中转文件,我们调试的 symbols 都会包含在这个文件中,并且每次编译项目的时候都会生成一个新的 dSYM 文件,位于 /Users/<用户名>/Library/Developer/Xcode/Archives 目录下,对于每一个发布版本我们都很有必要保存对应的 Archives 文件 (AUTOMATICALLY SAVE THE DSYM FILES这篇文章介绍了通过脚本每次编译后都自动保存 dSYM 文件)。
如果不用dSYM来符号化的话我们只能看到一堆的16进制地址,但是如果有这个dSYM文件我们就可以通过一些方法和手段将16进制的地址还原成函数或者方法名,供我们分析出现崩溃的原因。以下是符号化和未符号化或者半符号化的对比:
没有符号化:
Snip20170531_498.png
半符号化:
Snip20170531_499.png
全符号化:
Snip20170531_500.png
.dSYM文件准备
首先注意一点,dSYM文件是只有通过Xcode打包Archive出来的才有,所以必须经过正规打包,此处推荐大家看看iOS打包的两种方式,在推荐的此文中请大家参考打包方式一。以下是找到.dSYM文件的步骤:
第一步:Xcode中window-->Organizer
Snip20170601_504.png
Snip20170601_506.png
Snip20170601_508.png
第二步:选择对应的.xcarchive文件,右键显示包内容
Snip20170601_511.png
第三步:将第二步中截图的.dSYM文件拷贝到我们自定义的目录中,比如我们新建一个文件夹crash,那我们就把.dSYM文件拷贝到新建的crash目录中。(顺便把.app文件也拷贝到crash目录中)。(crash文件的路径:/Users/电脑名/Desktop/crash)
Snip20170601_512.png
PS: 如果是通过其他方式打包的,比如说通过iTunes打包的,那么是不会有这个.xcarchive文件的,也就不会有对应的.dSYM文件了,如果是这种情况的话,那现在你必须找到提交Appstore时候的版本(论版本控制的重要性),用同一台电脑(注意:一定是同一台电脑)然后用iOS打包的两种方式中的方式一再打一次包,使用Xcode重新上传到Appstore,如下图操作,再UpLoad to App Store。
1)修改一下配置:Build Settings-->搜dsym 选项改为DWARF with dSYM file
Snip20170601_515.png
2)再Archive一次,如果还没有,然后选择upload to App store,再选择的Download dSYMs:
Snip20170601_518.png
Symbolicatecrash工具
Symbolicatecrash是Xcode自带的一个分析工具,可以通过机器上的崩溃日志和应用的.dSYM文件定位发生崩溃的位置,把crash日志中的地址替换成代码相应位置。
Symbolicatecrash是Xcode上一个独立的工具,你打开终端是运行不了他的,因为环境变量没有配置,无法全局使用,所以现在只能先把这个工具在MAC上找到,然后拷贝出来,和.dSYM文件和Crash文件放在一起,然后再使用此工具。
Symbolicatecrash工具准备
1>路径:Symbolicatecrash工具的在xcode中的位置
Xcode4.3之前路径:
/Developer/Platforms/iPhoneOS.platform/Developer/Library/PrivateFrameworks/DTDeviceKit.framework/Versions/A/Resources/symbolicatecrash
Xcode4.3之后路径:
/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/PrivateFrameworks/DTDeviceKit.framework/Versions/A/Resources/symbolicatecrash
Xcode6之后路径:
/Applications/Xcode.app/Contents/SharedFrameworks/DTDeviceKitBase.framework/Versions/A/Resources/symbolicatecrash
Xcode8之后路径:
/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash
PS:Xcode7和Xcode8 symbolicatecrash的路径
如果大家发现这以上几种情况都找不到symbolicatecrash工具,那么不妨使用以下命令来找出symbolicatecrash工具的路径,在终端输入以下命令,稍等3分钟左右:
find/Applications/Xcode.app-name symbolicatecrash-typef
这三分钟主要是系统在搜寻symbolicatecrash工具的路径所耗费的时间,然后成功之后会显示以下截图:
Snip20170601_501.png
2>拷贝:将symbolicatecrash工具拷贝到上面创建的crash目录中
进入到目录下找到symbolicatecrash直接拷贝,command+c:
Snip20170601_513.png
或者是使用命令,将symbolicatecrash工具拷贝到相应路径:
cp /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/PrivateFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash /Users/电脑名/Desktop/crash
经过以上第一种直接拷贝或者命令拷贝的方式都能得到以下的结果:
Snip20170601_514.png
crash文件准备
把iTuenes Center的解决方案中心.crash文件下载下来,复制到crash文件夹中,或者如果是运营负责的话找运营要就好了。
Snip20170601_519.png
放好之后的结果:
Snip20170601_520.png
开始解析
第一步:终端中进入到crash文件夹目录:/Users/电脑名/Desktop/crash
Snip20170601_523.png
第二步:使用以下命令:
./symbolicatecrash ./*.crash ./*.dSYM > crash.log
Snip20170601_524.png
PS: 如果报以上错误,那么再输入如下命令:
exportDEVELOPER_DIR=/Applications/Xcode.app/Contents/Developer
然后再次输入命令./symbolicatecrash ./.crash ./.dSYM > crash.log
这个在解析的过程中需要一些时间的,稍等片刻,等到命令执行完成之后如下那么就可以看下crash.log文件了(当然你可以把crash.log改成你想要的任意后缀都行)
Snip20170601_525.png
第三步:生成crash.log文件后,直接打开查看已经对自定的方法和类符号化了,但是对于系统的UIKit和Foundation并未符号话:
我们要根据这份崩溃日志进行定位bug
-首先,我们要准备三份文件
1,就是上图的崩溃日志,后缀要改成 XXX.crash
2,获得崩溃这个版本的二进制文件的dSYM文件
Xcode -> Window -> Organizer
image.png
image.png
image.png
3,从Xcode里拿到解析的工具symbolicatecrash
image.png
image.png
将上述三个文件复制出来放到一个文件夹里
image.png
1,打开终端 cd 到当前文件夹
2,输入命令行./symbolicatecrash ./crashlog.crash ./Travel.app.dSYM > MyCrashlog.log
image.png
如果出现DEVELOPER_DIR is not defined at ....这种情况 需要设置一下环境变量
在终端输入export DEVELOPER_DIR=/Applications/Xcode.app/Contents/Developer//临时设置改环境变量
image.png
3,再输入./symbolicatecrash xxx.crash xxx.app.dSYM >MyCrashlog.log(xxx你自己对上你的文件名)
4,成功之后会有一个日志,里面就会有相应调用方法崩溃的栈信息
作者:Demonboy
链接:https://www.jianshu.com/p/5728e2cd4d86
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。