基于 ThinkPHP的友盟推送实现

为什么选择友盟?

友盟是一个集合APP 数据统计、第三方登录、消息推送、IM 等功能的第三方平台,在 APP 的初级阶段,能提供小企业的产品一站式的解决方案,挺实用的,这次就将消息推送的功能记录一下,以便往后回忆。

基础信息

版本:

ThinkPHP 3.2.3

友盟SDK U-PUSH 3.0,PHP SDK  下载地址

demo 演示


下载下来的 php 代码,直接修改一下 demo.php 里边的 配置参数、device_token 就可以跑起来能接收到推送消息了,那说明 DEMO 没问题,下一步就是融合到 ThinkPHP 去。

Demo1


基于 ThinkPHP的友盟推送实现_第1张图片
Demo2


场景

常见的情况有下面几种:

1. 所有的用户都收到同样的通知

2. 指定的单个用户收到指定通知

3. 指定的若干用户(组)收到通知

其实这些友盟都帮我们考虑好了,按照规则调用就可以了。

基于 ThinkPHP的友盟推送实现_第2张图片
友盟消息推送范围


思路

1. 友盟 PHP SDK 导入到 ThinkPHP 的第三方库的位置去,引入;

2. 重写调用的方法,将要推送的内容改为方法参数,可变,并且能给 API 或者后台随时调用;


先是将 SDK 文件 copy 到 ThinkPHP/Library/Org/Util 目录,demo.php 重命名 为 Umengnotification.class.php


基于 ThinkPHP的友盟推送实现_第3张图片

Umengnotification.class.php 添加 命名空间 以及类名保持一致,去掉自动执行的demo 代码


基于 ThinkPHP的友盟推送实现_第4张图片
添加命名空间


注释掉


原有的方法将默认值改为获取参数方式,方便变化内容

基于 ThinkPHP的友盟推送实现_第5张图片
对比

需要调用的时候,$device_token 可以传单个或者多个(多个时候需要用逗号隔开,不超过50个)

基于 ThinkPHP的友盟推送实现_第6张图片
调用规则

如果需要其他的推送内容(如标题,点击打开后需要接收的参数等,就可以修改一下这个方法,传入更多的变量值即可)


基于 ThinkPHP的友盟推送实现_第7张图片
推送效果

扩展

1. 消息推送的 trigger 可能是后台运营需要发送给对应的人,也可能是APP 其他用户的操作需要通知到交互的另外一个用户。所以 UmengPUSH 就设计为一个单独的调用方法,通过 ThinkPHP 的 A 方法,既可以被 API 内调用,也可以在后台逻辑里边调用。

2. 消息送达后,点击消息,APP 会接收到指定的自定义参数信息,需要统一起来管理,能够方便 iOS 和 Android 设备同时统一识别和解析,已达到同样的跳转效果。


基于 ThinkPHP的友盟推送实现_第8张图片
总结出来的差异化

其他

一个 APP 常见的设计有:

Banner 显示、消息推送、H5页面跳转,这些都希望能够实现和 APP 内页的交互。

因此需要将三者都考虑融合到一起,如采取统一的参数命名,调用同一个方法来实现应用内跳转,至于或者参数值的方式就根据各种情况来单独获取。


基于 ThinkPHP的友盟推送实现_第9张图片

你可能感兴趣的:(基于 ThinkPHP的友盟推送实现)