iOS通过.ips文件以及symbolicatecrash解析崩溃日志

引导:

  1. 如何获取.ips文件

2.如何获取symbolicatecrash

3.解析前的准备工作

4.如何将.ips转为.crash文件

5.如何使用symbolicatecrash解析.crash文件

6.异常错误处理

1.如何获取.ips文件?

在 iOS 中,你可以通过几种方式找到应用程序的 .ips 文件,具体取决于你是在开发过程中还是从用户设备上获取崩溃日志。

在开发过程中
1). 在 Xcode 中查看:如果你在 Xcode 中运行应用程序时发生崩溃,可以在 Xcode 的导航器中查看和导出崩溃日志。在 Navigator 面板中展开 "Devices and Simulators",选择连接的设备,点击“Open Recent Logs”,此时会进入 "Device Logs" ,找到项目相关的崩溃日志。

在设备的 Console App 中查看:在 macOS 的 Console 应用程序中,你可以连接设备并查看设备的系统日志,包括应用程序的崩溃日志。

2). 从用户设备上获取
使用设备的崩溃日志:如果用户在应用程序崩溃时选择了“发送报告”或“不发送”选项,你可能会收到一个带有 .ips 扩展的崩溃日志文件。用户通常可以通过设备设置中的“隐私”->“分析与改进”->“分析数据”找到,一般app的崩溃日志名为“项目名xxx-发生时间.ips”

从 iTunes 或 Finder 备份中提取:如果用户同步设备或使用 iCloud 进行备份,你可能会在 iTunes 或 Finder 备份中找到崩溃日志文件。

将.ips文件复制到新建的文件夹中.
2.如何获取symbolicatecrash?
1).打开终端,输入如下指令

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

终端会输出symbolicatecrash所在路径,如图所示


image.png

2). 复制地址进入到Resources文件夹下

cd /Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/

3).打开文件夹,然后找到并找到symbolicatecrash

open .

4).将Resources文件下的symbolicatecrash复制到步骤1新建的某个文件夹下(注:为了方便操作,最好将symbolicatecrash放到新文件夹下,后续在此文件夹还会放入.ips文件和dsyms中的xxx.app.dSYM)

3.解析前的准备工作
目前已存放了.ips崩溃日志和symbolicatecrash。需要解析日志,还需要重要的dSYM,也就是符号表。

那么如何获取“项目名xxx.app.dSYM”呢?

打开Xcode,导航栏选择“Window” -> “Organizer”,在“Archives”中找到崩溃的app版本,鼠标右击,选择“Show in Finder”,选择"xxx.xcarchive",鼠标右击,选择“显示包内容”,打开“dSYMS”,找到"项目名xxx.app.dSYM"文件,复制到文件夹中(.ips文件和dsyms中的xxx.app.dSYM 同一个文件夹).

4.如何将.ips转为.crash文件
因为苹果在Xcode13.3已经废弃了.crash文件,而symbolicatecrash只能解析.crash,所以需要利用"AppleCrashScripts"将.ips转换为.crash。

1). 下载AppleCrashScripts; https://github.com/tomieq/AppleCrashScripts

2). 进入下载的AppleCrashScripts-master文件夹,执行如下代码

 cd AppleCrashScripts-master 
swift convertFromJSON.swift -i xxx.ips -o xxx.crash

代码解释:
"/xxx/xxx.crash"为步骤4转换后的.crash文件的绝对路径
"/xxx.app.dSYM" 为步骤3获取的符号表文件路径
"crash.log"为解析后的崩溃日志名(文件名和后缀可以自定义.log,.txt都行)

此时如果没有报错的话,crash.log就可以看到带崩溃的具体函数和崩溃在哪一行了

6.异常错误处理
错误1:

Error: "DEVELOPER_DIR" is not defined at ./symbolicatecrash line 69.

解决方案:

export DEVELOPER_DIR="/Applications/XCode.app/Contents/Developer"

再次执行:

./symbolicatecrash /xxx/xxx.crash /xxx.app.dSYM > crash.log

好的效率,在于好的习惯!!!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。