iOS 10 在进行 Socket 通讯产生的坑...

关键词

CocoaAsyncSocket Socket iOS 10 网络权限弹框

症状

昨天,为了可以让硬件的同事测试 UDP Socket 收发包,所以去写了一个集成了 CocoaAsyncSocket 可以完成基本持续发包的 Demo 。但是拿同事的手机,一直都没有看到建立连接-发包成功等等的回调。
然后测试了其他多款不同型号,不同机型的手机,都没有出现这个问题。

定位问题

  1. 代理失效?
    因为从程序运行的结果直观的来看,只是没有回调返回。所以直接入回调方法入手,到 GCDAsyncUdpSocket.m 的源码中打断点,结果一路单步过来,发现delegate始终都是有的,而且涉及到 Delegate 的方法一直都没有被调用。
  2. 网络错误?
    在之前在对 GCDAsyncUdpSocket.m 的源码的探究中,了解到它的源码是由下面几部分构成
Configuration / Delegate Helpers / Errors / Utilities
Diagnostics / Binding / Connecting / Multicast
Reuse port / Broadcast / Sending / Receiving
Closing / CFStream / Advanced / Class Methods

所以直接从Error部分入手,在每个方法的开始打断点,当进行发包的时候,发现程序停在了- errnoErrorWithReason:这个方法里。这个方法中通过 NSString *errMsg = [NSString stringWithUTF8String:strerror(errno)]这段代码来获取错误信息,errno 这是什么呢?

  • errno

errno 是记录系统的最后一次错误代码。代码是一个int型的值,在errno.h中定义。我们可以通过检查errno这个值,来获悉系统发生错误的原因。在这个库中,errno值可以让我们定位到 socket 通信中产生的错误。

errno.h这个文件中,宏定义了一部分系统中各种产生的错误,并对应着errno的值。

然后查找到errno的值是65,对应的错误是no route to host 就是无法进行网络访问。

问题原因

因为定位到了问题在于没有网络访问,所以通过 iOS 10 无法访问网络等关键词查到了 大神仓的文章 iOS 10 的坑:新机首次安装 app,请求网络权限“是否允许使用数据” 以及其中提到的稀土的一篇讲 关于 iOS 10 应用程序网络请求许可弹窗解决方法的文章。
其中说到了由于大陆相关部门出台的新规定指出,应用在未经用户允许的前提下,系统不能授予其使用联网、获取定位的功能,所以只有在用户点击了弹窗允许访问网络的时候,应用程序才能访问网络。
然后发现,我拿的这个手机的蜂窝移动数据界面,果然是需要设置应用程序允许访问网络的那款。

左图是不会弹框的机型,右图则是会的

系统的BUG

引用掘金的一句话说明一下我遇到的情况...
如果你在 iOS 10 操作系统中安装了一个新应用或者第一次打开某个应用时发现应用出现无法访问网络无法刷新数据的情况,并且在蜂窝数据网络的设置项中无法找到相应应用的联网权限设置选项

看了掘金的文章,他们定位的原因是:iOS 10 系统没有正确地配置网络权限,所以触发一下系统的相关设置改动可能能够重新激活应用的联网权限请求弹窗

然后又咨询了一下公司的大神,公司的大神表示看到了很多,基本上直接使用socket通讯是一般是不会触发联网权限的。然后查到了** EsptouchForIOS** 程序的issue,里面有这样的解答。
经过研究发现,ios9直接升级到ios10.0.1的所有应用默认关闭所有网络权限,ios9直接升级到ios10.0.2的所有应用默认打开所有网络权限。但是,我们的Esptouch使用的都是底层的Socket函数,未使用Cocoa Touch框架。所以,未向用户申请Network权限。
然后 Demo 使用的UDPAsyncSocket.h中,使用也是底层的Socket函数。。。

解决方案

于是在 Demo 进行 socket 发包前

  • 进行了一次URLSession的请求来触发网络权限的弹窗
  • 并重置了一下手机的网络设置。
  • Run
    Bingo!!!之后就成功的看到了权限弹窗,点击之后,可以成功发包了

参考链接

下面是一些产品碰到这个问题的解决方案,毕竟我这只是一个用于调试 UDP Socket 发包的 Demo。
EsptouchForIOS关于这个问题的解答
iOS 10 不提示「是否允许应用访问数据」,导致应用无法使用的解决方案
iOS 10 的坑:新机首次安装 app,请求网络权限“是否允许使用数据”
ios10网络权限问题

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

推荐阅读更多精彩内容