产品的角度:功能需要,比如说资讯类产品的新闻推送、工具类产品的公告推送等等
运营的角度:活动运营需要,比如说电商类产品的促销活动;召回用户 / 提高活跃度等等
作为开发者,不要有需求就接,应该多思考、多理解用户 / 功能的使用场景,有助于我们更好地去选择合适的开发方式
系统级别:任何时候都可以推送给用户,且不会被系统杀死
Android的消息推送服务称为:C2DM(Cloudto Device Messaging)
消息推送的本质是:App将服务器更新的信息推送给用户,即App获取服务器信息,再推送给用户
App从服务器获取最新消息的基本方式(原理)有3种:Push、Pull 和 SMS
经总结,Android中实现消息推送的有7种主流解决方案,接下来将一一介绍。
4.1 C2DM
定义:Cloud to Device Messaging,云端推送
Android系统级别的消息推送服务-Google出品
原理:基于Push方式,C2DM服务负责处理诸如消息排队等事务,并向运行于目标设备上的应用程序分发这些消息。如下图:
定义:轻量级的消息发布/订阅协议
原理:基于Push方式,wmqtt.jar 是IBM提供的MQTT协议的实现,原理如下图:
其他三种:
客户端
通信能够在这三者的任意两个之间双向发生。
原理流程
现今主流的推送平台分为
手机厂商类:小米推送、华为推送。
第三方平台类:友盟推送、极光推送、云巴(基于MQTT)
BAT大厂的平台推送:阿里云移动推送、腾讯信鸽推送、百度云推送
这个是因为app更新的机制有两种,一种是app自身会有机制和app的服务器通信,获知版本更新的情况,并显示在app内。另一种是app新版本在appstore上架,appstore来提示有新版本更新。遇到这种情况应该是app确实有更新,但还没有上架appstore,所以有个时间差,等段时间,appstore也会有提示的。请采纳,谢谢。通常,刷新机制有以下三种:
手势刷新
通过手指在屏幕上进行“左划、右划、上划、下划”或者是“捏合、扩展、横折勾”等产品自定义的手势进行刷新,下拉刷新、上拉加载也属于手势刷新的一种。
点击刷新
通过点击一个按钮达到刷新数据的目的,目前主要用于网络异常导致需要点击重新加载,其余的应用场景都逐步减少了。
自动刷新
根据设定好的规则,如时间、事件规则自动向服务器获取新数据并替换旧数据。使用自动刷新需要根据场景来考虑是否合适。
场景一:对于频繁更新的内容、有时效性的内容,用户在一个设定的时间没有使用,则可考虑在下次使用时,自动刷新,把新的内容推送给用户。
类似微博、新闻这种具有时效性的产品,用户在24小时内未打开产品,则在下次打开时帮用户自动更新Timeline。
场景二:对于一个相对稳定,数据不会经常变化的页面,可以考虑设定时间规则,在后台为用户默默更新数据并替换旧数据。
欢迎分享,转载请注明来源:夏雨云
评论列表(0条)