服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - IOS - iOS下一键调试Push的方法详解

iOS下一键调试Push的方法详解

2021-04-22 18:00mrpeak IOS

这篇文章主要给大家介绍了关于iOS下如何一键调试Push的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。

前言

来湾区工作的一项有趣之处,是可以和来自完全不同工程文化背景的程序员们碰撞交流,语言习惯,教育环境,思维模式,工程经验都存在不小的差异。来湾区半年有余,这段时间下来有一点我感受颇深,这边的程序员非常强调做一件事的效率。在遇到一个有挑战性的项目时,前期的设计讨论调整非常频繁以求最优路径抵达目标,平常做项目时,各个程序员都有自己的工具箱和小脚本来应付各类场景。目的是都花最少量的时间干最多的活,又或者是为了不加班 :)

闲话不提,这篇文章和大家分享一个我之前调试 apn 的方式。

场景:测试又又又发现收不到 push 了

测试同学每隔一段时间就会发现 iphone 又收不到 push 了,这是经常发生在上家公司的场景(湾区好像很多公司都没测试),最后调试下来原因各不相同,但每次都免不了停下手头的工作走一遍流程:数据线连手机,查看 uuid,启动虚拟网卡,运行 wireshark 或者 tcpdump 抓包,排除 server 端问题,查看手机设置。等定位好问题至少已过去十多分钟,白白浪费的十多分钟。上述场景发生过几次之后,我写了个简单的小工具来应对。

问题:如何提升效率

我希望能将网络抓包这一流程尽可能简化,首先调试定位是否是 apple 服务器没有发送 push,最好能一键完成操作。用脚本一步步来实现。

第一步,连上测试 iphone 之后,自动获取 uuid

我们可以在 terminal 用 system profiler 命令来获取连接 mac 的 usb 设备:

?
1
system_profiler spusbdatatype

system_profiler 是一个用来获取当前系统软硬件配置信息的命令,可以通过 man system_profiler 查看详细使用方法。上述命令执行结果如下:

iOS下一键调试Push的方法详解

可以清楚看到通过 usb 连接的 iphone udid 数据(serial number),我们用 sed 提取出目标信息即可:

?
1
system_profiler spusbdatatype | sed -n -e 's/serial number: (.+)/\1/1p'

我只提取了第一个匹配结果,因为我一般只会通过 usb 连一个 ios 设备。

第二步,创建虚拟网卡以便抓包

我们只需要将上面提取的设备 udid 作为参数传人创建网卡命令:

?
1
system_profiler spusbdatatype | sed -n -e 's/serial number: (.+)/\1/1p' | xargs rvictl -s

执行完上述命令,应该能看到如下输出:

?
1
starting device 198a630825ee39496411dc3e323039f2947fa16f [succeeded] with interface rvi0

第三步,启动 tcpdump 监控虚拟网卡

同理,我们只需要等 rvictl 命令执行完毕之后,启动 tcpdump 即可。从第二步的输出里知道虚拟网卡的 id 为 rvi0,所以我们将命令修改如下:

?
1
system_profiler spusbdatatype | sed -n -e 's/serial number: (.+)/\1/1p' | xargs rvictl -s | sudo tcpdump -i rvi0

首次 sudo tcpdump 的时候会需要输入管理员密码,如果一切正常,那么会看到如下输出:

?
1
2
3
4
tcpdump: warning: rvi0: that device doesn't support promiscuous mode
(biocpromisc: operation not supported on socket)
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on rvi0, link-type pktap (apple dlt_pktap), capture size 262144 bytes

第四步,调整参数

虽然我们已经启动了抓包流程,但我们的目标是调试 push,所以我们只对 apn 过来的网络包感兴趣,接下来要对 tcpdump 增加包的 filter,设置一些简单参数。

这里需要一点对 ios apn 相关的了解,据我分析 apn 的数据通道情况是:在 ios 9 之前,apple 有一个专门的长链接通道来推送应用的 push,而且端口号固定在 5223。从 ios 9 开始,apple 开始采用 http 2.0,新建了一个综合用处的 http 2.0 长链接通道,这个综合通道应该不止会推送 push,所以抓包的时候会看到包的数量多于之前的 5223 通道。现状是:apple 在新版系统里同时用了两个通道,所以 apn 有时候走 5223,有时候又是走 http 2.0,策略不明。

简单分析之后,目标明确,我们只需要对端口做限制即可。http 2.0 毫无疑问会用 https,端口是走 443,所以我们最后的命令调整如下:

?
1
system_profiler spusbdatatype | sed -n -e 's/serial number: (.+)/\1/1p' | xargs rvictl -s | sudo tcpdump -i rvi0 src port 5223 or https

第五步,快捷启动

我们不可能每次都敲一边上面这一长串命令,为了操作方便,我们可以给命令加个 alias,编辑 .bash_profile:

?
1
vim ~/.bash_profile

加入命令别名:

?
1
alias apn="system_profiler spusbdatatype | sed -n -e 's/serial number: (.+)/\1/1p' | xargs rvictl -s | sudo tcpdump -i rvi0 src port 5223 or https"

启用配置

?
1
source ~/.bash_profile

第六步,验收成果

下次测试同学再来调试 push 收不到的问题,插上 usb 之后,我只需要:

1 按 f2 启动 terminal(我 mac 系统通过 bettertouchtool 设置的快捷键)

2 输入 apn 回车

bingo,接下来就可以喝口咖啡,安安静静看包了。

总结

上面的脚本只是将一些小工具结合利用,就能起到节约时间精力的疗效,开发过程中类似的例子有很多,总有一些工具或途径能提升我们的开发效率,多思考就有收获,大家在平常工作时也可以多琢磨下怎么利用工具提高生产力。

由于 fb 确实不用加班,我的空余时间突然多了起来,所以计划着今年多更新点文章。文章的重点会放在思路心得分享上,以短篇好消化为主。类似这篇文章目的在于分享用工具提升效率节约时间的思想。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。

原文链接:http://mrpeak.cn/blog/ios-debug-apn/

延伸 · 阅读

精彩推荐
  • IOS解析iOS开发中的FirstResponder第一响应对象

    解析iOS开发中的FirstResponder第一响应对象

    这篇文章主要介绍了解析iOS开发中的FirstResponder第一响应对象,包括View的FirstResponder的释放问题,需要的朋友可以参考下...

    一片枫叶4662020-12-25
  • IOSiOS布局渲染之UIView方法的调用时机详解

    iOS布局渲染之UIView方法的调用时机详解

    在你刚开始开发 iOS 应用时,最难避免或者是调试的就是和布局相关的问题,下面这篇文章主要给大家介绍了关于iOS布局渲染之UIView方法调用时机的相关资料...

    windtersharp7642021-05-04
  • IOSiOS 雷达效果实例详解

    iOS 雷达效果实例详解

    这篇文章主要介绍了iOS 雷达效果实例详解的相关资料,需要的朋友可以参考下...

    SimpleWorld11022021-01-28
  • IOSiOS中tableview 两级cell的展开与收回的示例代码

    iOS中tableview 两级cell的展开与收回的示例代码

    本篇文章主要介绍了iOS中tableview 两级cell的展开与收回的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    J_Kang3862021-04-22
  • IOSIOS 屏幕适配方案实现缩放window的示例代码

    IOS 屏幕适配方案实现缩放window的示例代码

    这篇文章主要介绍了IOS 屏幕适配方案实现缩放window的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    xiari5772021-06-01
  • IOS关于iOS自适应cell行高的那些事儿

    关于iOS自适应cell行高的那些事儿

    这篇文章主要给大家介绍了关于iOS自适应cell行高的那些事儿,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    daisy6092021-05-17
  • IOSIOS开发之字典转字符串的实例详解

    IOS开发之字典转字符串的实例详解

    这篇文章主要介绍了IOS开发之字典转字符串的实例详解的相关资料,希望通过本文能帮助到大家,让大家掌握这样的方法,需要的朋友可以参考下...

    苦练内功5832021-04-01
  • IOSiOS通过逆向理解Block的内存模型

    iOS通过逆向理解Block的内存模型

    自从对 iOS 的逆向初窥门径后,我也经常通过它来分析一些比较大的应用,参考一下这些应用中某些功能的实现。这个探索的过程乐趣多多,不仅能满足自...

    Swiftyper12832021-03-03