产品炸了 | 微信即将下线模板消息

JAVA架构日记

共 1609字,需浏览 4分钟

 ·

2021-01-30 23:23

背景

  • 微信于今日宣布 《服务号模板消息能力调整》,原先的模板消息能力将于 2021 年 4 月 30 日 24:00 下线,届时将无法使用此接口发送模板消息。

  • 简单来讲,向小程序开发看齐,不能直接通过公众号向已订阅的用户推送模板消息。例如:改版后即使订阅了 招商银行信用卡中心,也无法通过公众号收到 动账、还款的消息提醒。

  • 笔者从事行业对于模板消息属于强需求,所以整理变更订阅通知 的改造和实现过程供大家参考。

名称解释

  • 一次订阅

指用户订阅一次,服务号可不限时间地下发一条对应的订阅通知;

  • 长期订阅

指用户订阅一次,服务号可长期多次下发通知,长期订阅通知仅向政务民生、医疗等公共服务领域开放;

  • 服务通知

微信默认开启服务通知功能,在用户聊天列表中会出现橙色的服务通知

d64110254b996954d9e3ee0471eaf798.webp服务通知

用户订阅流程

d9e3e1d9ee13b4239a0d3da4f2383bac.webp用户订阅
  • 如上图, 用户可以通过点击公众号发布的图文中插入多个订阅通知的按钮,用户点击图文中的按钮订阅
ef8e14fdaa872b8a42c8f12e8ce1529c.webp1611845657
  • 如上图,用户在在开发者提供的 H5 页面中,通过 JSSDK 拉起订阅按钮
7f6319265ec11849cccd0af99ebfab0d.webpJSSDK 拉起示例
// 首先导入 JSSDK http://res2.wx.qq.com/open/js/jweixin-1.6.0.js
<wx-open-subscribe template="TenvU22BA1jCp4YHfYEpRuESXYReQyDuhs4vbdWA99I" id="subscribe-btn">
    <template slot="style">
    <style>
      .subscribe-btn {
          color#fff;
          background-color#07c160;
      }
     
style>
     template>
     <template>
        <button class="subscribe-btn">
          上课通知
         button>
      template>
wx-open-subscribe>
<script>
var btn = document.getElementById('subscribe-btn');   btn.addEventListener('success'function(e){
     // 根据回调确定用户是 取消 还是允许
    // 如果无法接收微信回调的情况下,需要在此处保存用户订阅的新姐
});
script>

接收微信回调的订阅事件

  • 用户在图文/H5 等场景内订阅通知的操作 , 会向开发者接口推送以下报文
<xml>
    <ToUserName>公众号微信号ToUserName>
    <FromUserName>用户 openidFromUserName>
    <CreateTime>时间戳CreateTime>
    <MsgType>(固定值)MsgType>
    <Event>(固定值)Event>
    <SubscribeMsgPopupEvent>
        <List>
            <TemplateId>模板 idTemplateId>
            <SubscribeStatusString>用户点击行为(同意、取消发送通知)SubscribeStatusString>
            <PopupScene>场景(图文、H5)PopupScene>
        List>
    SubscribeMsgPopupEvent>
xml>
  • 根据推送报文,保存至用户和订阅模板关系表,供下文推送使用

推送通知流程

d1876f57e977236eca00e04c6c552314.webp下发通知
  • 调用微信服务发送订阅通知
POST https://api.weixin.qq.com/cgi-bin/message/subscribe/bizsend?access_token=ACCESS_TOKEN
  • 请求参数说明
{
  "touser""接收者openid ,必须是已经订阅此消息模板的用户,不然无法推送",
  "template_id""消息模板ID",
  "page""点击跳转的链接",
  "data": {
      "name1": {
          "value""冷冷"},
       "time7": {
          "value""2021-01-28 23:15:42"
      }
     }
}

问题汇总

  • 长期订阅通知申请问题

目前开发的行业较少 (政府、公共)其他行业是否开放长期订阅需要提前提供材料申请,避免模板消息到期后导致业务阻塞。

  • 框架适配问题

目前主流微信开发 SDK (WxJava、 JFinal Weixin) 还未有相关的事件实现、接收报文等需要开发者自己处理。

  • 避免用户取消授权

在 H5 页面 JSSDK 拉起用户 【允许】、【取消】都会有回调事件,在取消情况给予用户明确说明,并做好短信通知的降级策略。


浏览 41
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报