为什么选择友盟?
友盟是一个集合APP 数据统计、第三方登录、消息推送、IM 等功能的第三方平台,在 APP 的初级阶段,能提供小企业的产品一站式的解决方案,挺实用的,这次就将消息推送的功能记录一下,以便往后回忆。
基础信息
版本:
ThinkPHP 3.2.3
友盟SDK U-PUSH 3.0,PHP SDK 下载地址
demo 演示
下载下来的 php 代码,直接修改一下 demo.php 里边的 配置参数、device_token 就可以跑起来能接收到推送消息了,那说明 DEMO 没问题,下一步就是融合到 ThinkPHP 去。
场景
常见的情况有下面几种:
1. 所有的用户都收到同样的通知
2. 指定的单个用户收到指定通知
3. 指定的若干用户(组)收到通知
其实这些友盟都帮我们考虑好了,按照规则调用就可以了。
思路
1. 友盟 PHP SDK 导入到 ThinkPHP 的第三方库的位置去,引入;
2. 重写调用的方法,将要推送的内容改为方法参数,可变,并且能给 API 或者后台随时调用;
先是将 SDK 文件 copy 到 ThinkPHP/Library/Org/Util 目录,demo.php 重命名 为 Umengnotification.class.php
Umengnotification.class.php 添加 命名空间 以及类名保持一致,去掉自动执行的demo 代码
原有的方法将默认值改为获取参数方式,方便变化内容
需要调用的时候,$device_token 可以传单个或者多个(多个时候需要用逗号隔开,不超过50个)
如果需要其他的推送内容(如标题,点击打开后需要接收的参数等,就可以修改一下这个方法,传入更多的变量值即可)
扩展
1. 消息推送的 trigger 可能是后台运营需要发送给对应的人,也可能是APP 其他用户的操作需要通知到交互的另外一个用户。所以 UmengPUSH 就设计为一个单独的调用方法,通过 ThinkPHP 的 A 方法,既可以被 API 内调用,也可以在后台逻辑里边调用。
2. 消息送达后,点击消息,APP 会接收到指定的自定义参数信息,需要统一起来管理,能够方便 iOS 和 Android 设备同时统一识别和解析,已达到同样的跳转效果。
其他
一个 APP 常见的设计有:
Banner 显示、消息推送、H5页面跳转,这些都希望能够实现和 APP 内页的交互。
因此需要将三者都考虑融合到一起,如采取统一的参数命名,调用同一个方法来实现应用内跳转,至于或者参数值的方式就根据各种情况来单独获取。