关于 iOS 设备如何接收到 push notificaton 的一点疑问 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
huanglexus
V2EX    iOS

关于 iOS 设备如何接收到 push notificaton 的一点疑问

  •  
  •   huanglexus 2015-02-12 16:28:17 +08:00 4800 次点击
    这是一个创建于 3968 天前的主题,其中的信息可能已经有所发展或是发生改变。

    之前看到一个帖子讨论支付宝或者微信这些的扫码登入/扫码支付,手机扫了码之后,电脑端也就收到反馈。

    回复说明了有两种实现方式:

    1. 轮询,不停地向服务端询问用户是否扫了码
    2. 用WebSocket之类的建立长连接,一旦用户扫码成功,服务器传回消息

    很明显第二种方法对服务器的压力更小。

    那我现在的题是,iOS 设备是如何收到来自苹果推送服务器发来的消息呢(似乎这和邮箱收信差不多?),应该不可能是轮询或者建立长连接吧。

    20 条回复    2015-02-13 16:07:35 +08:00
    magicianzrh
        1
    magicianzrh  
       2015-02-12 16:50:22 +08:00   1
    找一个类似这种http://xg.qq.com/
    magicianzrh
        2
    magicianzrh  
       2015-02-12 16:52:47 +08:00
    没打完字就回复了
    这种sdk目前很多的,找一个差不多的
    你可以通过tag呀之类的发

    不过嘛如果你想对某个账号做得好一点么 remote push还是自己搞搞比较好
    yttyhf2006
        3
    yttyhf2006  
       2015-02-12 16:57:57 +08:00
    APNS => Apple Push Notification Services

    链接仅供参考
    http://blog.csdn.net/ryantang03/article/details/8482259
    caoyue
        4
    caoyue  
       2015-02-12 19:33:18 +08:00 via iPhone
    TCP 长连接
    加心跳机制
    weisoo
        5
    weisoo  
       2015-02-12 19:42:06 +08:00   1
    IOS设备和苹果官方服务器建立一条长链接,所有软件如果要向IOS设备发送消息,都通过这条链接。
    huanglexus
        6
    huanglexus  
    OP
       2015-02-12 23:11:18 +08:00
    @weisoo 这个连接是只要联网就一直建立?
    huanglexus
        7
    huanglexus  
    OP
       2015-02-12 23:12:32 +08:00
    @magicianzrh 我只是对这个实现比较好奇= =
    yellowV2ex
        8
    yellowV2ex  
       2015-02-12 23:23:30 +08:00   1
    @huanglexus 安卓不知道,苹果是直连,因为苹果推送是iOS处理不是app自己去连接的。
    wadezhao
        9
    wadezhao  
       2015-02-12 23:24:58 +08:00
    没看懂你的问题。

    手机扫码,电脑网页有了反应,这明显是手机向Server提交了信息,然后Server再“PUSH(姑且这么称呼)”了信息到电脑浏览器上。

    这和iOS如何收到推送,有什么关系?

    另外iOS的推送就是系统维持一个长连接,这个可以搜到很多文章介绍。
    wadezhao
        10
    wadezhao  
       2015-02-12 23:26:39 +08:00   1
    @yellowV2ex 安卓现在官方也有一个推送方案,是模仿苹果,由安卓系统去维持一个统一的长连接。
    可惜这个方案依赖Google框架,所以国内的软件基本上都是各个APP各自为政,国外大一些的软件如果不想放弃大陆市场,也必须有自己的推送方案。
    感谢党,感谢国家………………
    huanglexus
        11
    huanglexus  
    OP
       2015-02-12 23:31:02 +08:00
    多谢大家,作为学完《数据通信与计算机网络》的大三学生居然从未听说过 TCP 长连接,真是不好意思 ~~~~~~~~
    yellowV2ex
        12
    yellowV2ex  
       2015-02-12 23:33:20 +08:00
    @wadezhao google这货也真是的,自己拍怕屁股走了,留下用户和开发商纠结一生
    weisoo
        13
    weisoo  
       2015-02-13 00:25:17 +08:00
    @huanglexus 是的,一直建立
    geeti
        14
    geeti  
       2015-02-13 00:45:18 +08:00
    @huanglexus 需要知道的是,运营商的Service router对idle的tcp链接是有timeout机制的,各个厂商的路由器不太相同,如果心跳时间间隔超过路由器的允许范围,tcp就会被阻断
    mornlight
        15
    mornlight  
       2015-02-13 00:55:17 +08:00
    你说的那个扫码场景,一般是走HTTP的。
    推送使用的当然不会是这个协议。
    dddd1919
        16
    dddd1919  
       2015-02-13 08:48:14 +08:00
    为什么很明显长链接对服务器的压力更小?明明是轮询么,另外像微信扫码那种,用的是长轮询
    zjuster
        17
    zjuster  
       2015-02-13 11:08:23 +08:00
    知乎曾有内部RD简单讲了下微信扫码登陆的产品逻辑。

    现在微信已经不用扫码登陆了,直接iOS Wechat点登陆就行了。
    c742435
        18
    c742435  
       2015-02-13 14:29:08 +08:00
    @huanglexus 有两种方式,轮询和长链接
    通常使用长链接。在长链接无法使用的时候使用轮询。
    记得很久很久以前 也许是ipad4的时代 推送是有选项的。上面写着如果基于长连接的推送不能使用时,可以自选到苹果服务器查询的频率,5分钟一查 30分钟一查什么的。
    standin000
        19
    standin000  
       2015-02-13 15:55:23 +08:00
    @zjuster 网页登陆,不用扫描了吗?
    zjuster
        20
    zjuster  
       2015-02-13 16:07:35 +08:00
    @standin000 我说的是mac 版...
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2961 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 96ms UTC 12:23 PVG 20:23 LAX 04:23 JFK 07:23
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86