美文网首页直播 IMiOS进阶之路iOS Developer
iOS开发——iOS静默推送介绍及使用场景

iOS开发——iOS静默推送介绍及使用场景

作者: 断风刀 | 来源:发表于2017-02-06 09:14 被阅读4759次

    静默推送

    先来看下普通推送和静默推送的区别:

    普通推送:收到推送后(有文字有声音),点开通知,进入APP后,才执行-- (void)application:(UIApplication didReceiveRemoteNotification:(NSDictionary fetchCompletionHandler:(void result))handler *)application *)userInfo (^)(UIBackgroundFetchResult

    静默推送:收到推送(没有文字没有声音),不用点开通知,不用打开APP,就能执行(void)application:(UIApplication )application)userInfo didReceiveRemoteNotification:(NSDictionary fetchCompletionHandler:(void (^)(UIBackgroundFetchResultresult))handler,用户完全感觉不到

    所以静默推送又被我们称做 Background Remote Notification(后台远程推送)。静默推送是在iOS7之后推出的一种推送方式。它与其他推送的区别在于允许应用收到通知后在后台(background)状态下运行一段代码,可用于从服务器获取内容更新。功能使用场景:(多媒体)聊天,Email更新,基于通知的订阅内容同步等功能,提升了终端用户的体验。

    所以我们对于静默推送的定义就是:后台远程推送,允许应用在收到通知后在后台运行一段代码,且能够马上执行-- (void)application:(UIApplication didReceiveRemoteNotification:(NSDictionary fetchCompletionHandler:(void result))handler *)application *)userInfo (^)(UIBackgroundFetchResult代理方法的一种推送方式

    通过下面两张图片你就可以很清楚地看出静默推送和其他远程推送的区别:

    Paste_Image.png a

    静默推送的使用:

    静默推送不仅在定义上和其他的推送方式不同,在推送内容上也和其他推送不同。在后台给应用的推送内容中只要满足下面的条件,该推送就是静默推送:
    ****如果只携带content-available: 1 不携带任何badge,sound 和消息内容等参数,则可以不打扰用户的情况下进行内容更新等操作即为“Silent Remote Notifications”****。
    下面我们通过Easy APNs Provider模拟推送软件看下静默推送的内容格式:

    Paste_Image.png

    静默推送的使用场景

    假设我们现在有下面的需求:****用户打开你的app,然后把你的app压到后台。这个时候如果你的app是有IM功能的,且即时通讯是用XMPP协议,或者MQTT协议,那你的即时通讯此时是会断开长连接的(应用处于后台会断开长连接),其他用户发消息给你,而你的的IM此时断开长连接,那么你就不会收到别人发给你的消息的推送****。
    上面场景的解决办法有两个,

    一:别人发消息给你其实是发到后台,后台再发送给你。那么你如果想你的应用在后台时其他用户发消息给你仍然可以出现推送,那你可以让后台在给用户发消息的时候,顺便将聊天内容发个推送给用户的app。这样,用户应用在后台时别人发消息给他他就会收到消息推送。但是这么做有个问题:会增加后台的工作量,且浪费用户的流量。可以想象下,如果你的应用有1000万活跃用户,当1000万用户同时进行聊天的时候,后台不仅需要发送消息,还要发送消息的推送,这就相当于后台需要承担多一倍的任务量。当大量进行数据收发的时候,就会容易出现问题。

    二:我们可以利用静默推送:当后台需要发送第一条消息给应用处于后台状态用户的时候,可以先给用户发送一个静默推送,将用户的app唤醒,这个时候应用有20秒的时候可以用来处理消息。让应用在收到消息后,再去发送一个本地的推送,提醒用户有其他用户给他发了消息。这样就能减少后台的任务量。

    所以如果你的推送使用的是原生的APNS消息推送,IM功能使用的是XMPP,MQTT协议,处理后台IM消息推送的时候就可以通过静默推送来完成消息的推送。极光推送本身也是这样进行处理的。

    相关文章

      网友评论

      • 心语风尚:把app杀死 可以静默推送吗 静默推送 是app必须在后台没有杀死吗 还是 app压根没有启动 就可以
        稻_草_人:@心语风尚 可以使用VoIP 推送唤醒app
        心语风尚:我印象中 压根没有办法 在杀死状态 执行写好的代码 或者 某个方法吧
        断风刀:@心语风尚 杀死之后是收不到的,而且用户把应用杀死了本身也就不应该出现通知的东西了。
      • PGOne爱吃饺子:大佬 你好,请问你一个问题啊,就是别人给你发消息的时候,后台是不是要判断你的应用是前台状态还是后台状态啊,因为如果你的应用在前台了,已经可以接收到别人发的消息了,那么此时在发送一个推送是不是很奇怪啊。
        断风刀:是的,这个需要你在后台监控设计的在线情况哦。但是如果对于消息的下发即时性要求不高,也可以保存未离线消息。下次重新建立TCP长连接的时候再把消息下发。
      • FongG:所以静默推送只能在app没有被杀死的时候调用吗?。。。。
        酷哥不回头看爆炸:@LEEgame 好像是获取不到的,
        zhengziyu:@简书吃枣药丸 兄弟,你好,问一下,如果app杀死,非锁屏状态,来一条推送,不点通知栏,点击icon打开App,怎么才能拿到刚才的推送内容?试了好多方法也不好使
        酷哥不回头看爆炸:我测试过后感觉是这样的。
        程序杀死之后 发送静默推送 是什么反应都没有的, 但是打开程序 会进入收到推送的代理方法。
      • 琥珀之剑:你还 ios10的静默推送会走哪个方法
        断风刀:@PGOne爱吃饺子 一样的,也是走这个方法。
        PGOne爱吃饺子:是啊,我也很想知道这个问题,iOS10之后静默推送还会走哪个方法,你知道了么
      • 指尖猿:推送:mushroom:带带我呀:heart_eyes:
        断风刀:推送不会很困难哦。苹果就是APNS,建议你可以去看下苹果的官方文档。

      本文标题:iOS开发——iOS静默推送介绍及使用场景

      本文链接:https://www.haomeiwen.com/subject/glsyittx.html