iOS获取用户设备崩溃日志并分析

项目最近发布,部分用户在内侧使用,正好遇到一些问题,由于用户在其他城市,所以对于用户设备产生的崩溃日志,不好直接拿设备连接电脑。

对于已发布的项目,若要收集崩溃日志,我们可借助于第三方工具,如Bugly、友盟等,或者苹果自己提供的一个SDK函数:NSSetUncaughtExceptionHandler 用来做异常处理,然后发送到自己服务器。

那么,如果我们都没有做这两步,该如何处理呢?其实我们可以让用户自己收集给我们。

 

步骤如下:

1、引导用户开启iOS设备设置->隐私->分析

这几个都开启一下,目的是允许系统设备自己记录和上传APP应用的崩溃日志数据。

 

2、点击上图的【分析数据】,会看到一个列表,里面记录了设备上所有应用的日志,找到我们自己的应用,获取到崩溃日志。

关于如何获取崩溃日志:

我摘了两段网上的话

1、当用户抱怨闪退时,你可以要求他让设备与iTunes同步,设备与电脑上的iTunes Store同步后,会将崩溃日志保存在电脑上(路径:Mac OS X:~/Library/Logs/CrashReporter/MobileDevice/)到上述位置把崩溃日志下载下来,然后通过电子邮件发送给你;用这个方法获取崩溃日志时,你必需尽量获取用户设备生成的所有崩溃日志。因为崩溃日志越多,就越容易诊断问题所在

2、应用提交到App Store后,你也能从 iTunes Connect 获取到用户的崩溃日志,登录到 iTunes Connect 上,选择 Manage Your Applications, 点击相应的应用,点击应用图标下面的View Details按钮, 然后点击右栏Links部分的 Crash Reports;如果没有崩溃日志,试试点击Refresh按钮刷新一下。如果你的应用用户量还不多,或者刚上架不久,iTunes Connect账号上也可能还没有任何崩溃日志;如果有的话你就会看到不同iOS版本用户下的崩溃信息。

 

3、当我们得到这个崩溃日志文件后,我们是看不懂的,原因是没有经过符号化

下面我们可以这样做:

a、桌面新建一个文件夹,把刚才的文件放进去

b、一般我们得到的这个文件都是以.ips后缀结尾,我们先修改后缀为.crash

c、打开如下路径,获取symbolicatecrash,并放到a中的文件夹

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

 

d、打开Xcode,到Organizer下面,获取你发布商店的Archives版本,show in finder 找到 .dsYM文件,同理放到a中的文件夹

 

 e、现在我们得到如下内容:一共3个文件

 

 f、最后一步,进行符号化解析

打开终端,cd到a的文件夹路径

【./symbolicatecrash】 【.crash文件路径】 【.dSYM文件路径】 【> log.crash】

记得每个之间有个空格,一共4部分组成。最后得到的符号化文件就是 log.crash。

 

比如我的路径是这样:

./symbolicatecrash /Users/MACBOOK/Desktop/符号化/k12_sl_iOS-2017-08-14-163111.crash /Users/MACBOOK/Desktop/符号化/k12_sl_iOS.app.dSYM > log.crash

 

结果如下:

 

打开log.crash ,我们就能看到具体内容了,错误崩溃定位的代码语句都是有的。

提示:这些引起崩溃代码一般都在文件前面部分。

 

至于文件里的内容分布,这里我就不讲解了,大家有兴趣网上搜一下都有的。

 

enjoy~

 

转载于:https://www.cnblogs.com/yajunLi/p/7360092.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值