微信开发(三)微信模板消息接口设计

说明

      在公司微信项目开发中,我主要负责消息中心的模板消息接口设计实现。主要是将微信公众号的推送模板消息功能放到公司的消息中心系统中,微信后台项目通过RMI调用接口,实现推送功能。在这里记录总结下当时的设计实现思路。
      公司使用Hessian实现RMI,所以接口设计为一个Hessian接口。

正文

接口的设计要先确定接口的名称,参数,返回值。这里由于考虑到了今后的扩展,可能会运营不止一个公众号,所以在接口参数的设计上,比较具体。

public interface IWechatMessageService {

    public int sendTempMsg(String spid, Integer templateId, String data);
}

通过阅读微信开发文档,我们知道了在推送模板消息时,必须要有Access_Token,templateid,openId和要发送的数据,这些数据组成一个json串发送给微信服务器,微信服务器返回一个json数据包包含对应的信息。

消息推送的设计思路:
      通过微信后台项目远程调用接口,公众号的id,模板的id(id均为在表中的主键),还有推送的数据作为参数传递,消息中心接受到参数后,首先会根据公众号id判断是否存在该公众号信息,再根据模板id判断是否存在模板信息,若都不存在问题,则会将这些参数数据组装成一个DTO,放入消息队列,此时接口方法执行完毕,返回状态码。放入消息队列后,有队列订阅者对消息进行处理(即发送数据到微信服务器),至此推送模板消息的流程结束。

在以上的思路中有几个问题:

  1. 对于公众号和模板信息的校验,这些信息都存储在数据库中,每次调用接口校验时都是否都需要从数据库查询数据?
  2. 对于推送的数据,这个参数是多用户数据,也就是一次传递一批用户的数据,每个用户推送的内容不同,所以数据格式为JsonArray,在往消息队列中投递的时候,是一次投递一批,一个DTO,还是将每个用户的数据查分组成DTO,进行投递?
  3. 消息数据进入队列后,如何消费,该怎样向微信服务器发送数据?
  4. 在推送时,需要Access_Token,这个token与微信后台项目是共用的,而且token是有有效期的,在过期时导致消息推送失败,该如何处理?

接下来针对每个问题记录下当时的解决方法:

1. 公众号、模板标识的校验

      在发送模板消息时,需要Access_Token和对应的模板id,Access_Token的获取需要公众号的appid和secret,定制模板需要向微信官方申请,而且是人工审核,十分严格。当运营不止一个公众号时就需要通过表记录公众号的信息,而且推送的内容不同使用的模板不同,也需要表记录使用的模板信息。所以传递的参数都应该在表中有记录,为了避免每次校验时查询数据库,这里采用了将公众号信息和模板信息加载到内存的方式。具体是使用一个监听器,在项目启动时,从数据库查询数据并存储到内存中,这里使用HashMap作为存储的数据结构,key为主键 value为对应的实体类对象。

//加载模板信息
private static Map<Integer,Template> ALL_TEMPLATE = new HashMap<Integer, Template>();
List<Template> templateList = templateService.getAll();
if (templateList != null && templateList.size() > 0) {
    for (Template template : templateList) {
        nteger templateid = template.getTemplateid();
        ALL_TEMPLATE.put(templateid,template);
    }
}

2.关于多用户数据的投递

在开始设计时,我采用的是直接将数据组装成一个DTO,发送到队列中,消费时是接受一批的用户数据,在发送时对数据做处理,拆分出

  • 0
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值