Android/PHP百度推送服务(非百度账户系统)

shilongdred 2014-02-11

考虑到百度的人才和技术底蕴,都没有做任何技术性考察就选择了百度推送,但是实际使用才发现百度的软件开发标准化流程还有待提高。

C/S模式推送的基本流程:
  • 服务器端发送消息到百度
  • 百度接收消息然后发送到客户端
  • 客户端接收消息并处理
基本概念:
  • 对于非百度账户系统的应用,每个移动设备都是不同的用户(不同的user_id),不同的终端标识(channel_id),这里的user_id和channel_id都是百度返回的变量,与自有系统无关。对于同一台设备同一个应用同一个用户,每次从百度返回的user_id和channel_id相同(有待验证)。
  • 而对于使用百度账户系统的应用,可使用百度账户登录,因此多个移动设备可使用相同的user_id。 
消息推送实现基本步骤(仅限移动应用自有账户系统的场景):
  • 申请API Key 及 Secret Key,参见官方说明;
  • Android客户端用户登录,记录用户uid;
  • Android客户端调用PushManager.startWork启动推送服务,调用onBind获得从百度返回的user_id和channel_id;
  • Android客户端将uid、user_id和channel_id发送到PHP服务器;
  • PHP服务器收到请求后查询(uid, channel_id)的记录是否已存在,若不存在则加入(表示编号为uid的用户所登录的编号为channel_id的终端,具有唯一性),若存在则检查user_id是否相同,如果不同则更新user_id;
  • PHP服务器查询编号为uid的用户所关联的终端,取出该用户对应的所有user_id;
  • PHP服务器遍历此user_id数组,调用$channel->pushMessage向该用户的所有终端推送消息;
问题:
  • PHP服务器端记录同一个用户的多个channel_id,但是很有可能对应的终端已失效,因此有必要同时记录其过期时间。每当Android客户端发送channel_id时刷新此过期时间,同时检查已过期的记录并删除。这样对于已过期的终端对应的user_id就不用多余的推送。

相关推荐