【微信小程序 + 消息订阅 + 授权】 微信小程序实现消息订阅流程介绍,代码示例(仅前端)

前言

微信小程序消息订阅包括一次性订阅和长期订阅(非永久订阅)。

让我们来一起看看怎么使用吧~

文档直通车:开放能力 /消息 /订阅消息 /小程序订阅消息(用户通过弹窗订阅)开发指南

文章目录

一、一次性订阅流程

1.配置订阅消息模板

登录微信公众平台,进入「功能」→「订阅消息」,从公共模板库中选择所需模板或申请自定义模板,获取模板 ID。

如果没有合适的模板,可以申请添加新模板,审核通过后可使用。

2.前端发起订阅请求

在小程序前端,通过调用wx.requestSubscribeMessage接口,向用户展示订阅弹窗。示例代码如下:

typescript 复制代码
wx.requestSubscribeMessage({
    tmplIds: ['TEMPLATE_ID'], // 模板ID列表
    success(res) {
        if (res['TEMPLATE_ID'] === 'accept') {
            console.log('用户已授权');
            // 将授权结果发送至服务器保存
            wx.request({
                url: 'https://api.example.com/save-subscription',
                data: { openid: getApp().globalData.openid }
            });
        }
    },
    fail(err) {
        console.error('授权失败', err);
    }
});

文档直通车:

3.服务端存储订阅关系

服务器接收到前端发送的授权结果后,校验用户身份,并存储openid、模板 ID 和授权状态等信息。

4.触发消息发送

当满足业务条件时,服务器调用微信的消息发送接口,传入openid、模板 ID、页面路径和消息数据等,发送订阅消息。

5.消息状态监控

服务器配置消息推送回调地址,接收微信推送的消息发送结果,更新数据库中的消息发送状态。

二、长期订阅流程

1.类目确认

确保小程序后台已正确选择支持长期订阅的类目,如政务民生、医疗、交通、金融、教育等部分二级行业类目。符合准入条件的,系统会自动在订阅消息功能模块内显示长期订阅入口。

2.模板选择

访问「类目模板库」,搜索与业务场景相关的长期订阅模板,如 "行为激励""积分通知" 等。

3.消息发送

使用服务端 API 调用subscribeMessage.send接口发送消息,消息内容需与所选模板字段完全匹配。

三、开通条件

1.一次性订阅

无需特殊条件,只要小程序具备合法的业务场景和内容,均可使用一次性订阅消息功能。

2.长期订阅

小程序必须属于政务民生、医疗、交通、金融、教育等部分二级行业类目,且长期订阅目前只支持少量民生公共服务节点通知。

3.一次性订阅中多个模板和单个模板
  • 单个模板:在基础库 2.4.4 - 2.8.3 版本中,仅支持传入一个一次性模板 ID,用户订阅后,开发者可不限时间地下发一条对应的服务消息。
  • 多个模板 :基础库 2.8.2 版本开始,用户发生点击行为或者发起支付回调后,才可以调起订阅消息界面,且一次调用wx.requestSubscribeMessage接口最多可传入 3 个模板 ID。iOS 客户端 7.0.6 版本、Android 客户端 7.0.7 版本之后的一次性订阅支持多个模板消息,每个模板消息可单独订阅或退订。


四、注意一些报错和弹框显示的逻辑

1."总是保持以上选择,不再询问"

  • 选中该状态,再点击"取消" or "允许": 弹框不会再弹出
  • 未选中该状态,点击"取消" or "允许":每一次到触发条件时,都会出来一次,订阅一次用一次。
2.判断用户是否授权,弹出引导弹框

整体逻辑上面也说过,其实就是通过 wx.getSetting 接口,来获取当前订阅的状态;通过总开关subscriptionsSetting.mainSwitch和模版的状态 (为 acceptorreject等)来判断用户是否订阅。

typescript 复制代码
const subscribeMessage = async(type) => {
  const {subscriptionsSetting} = await wx.getSetting({withSubscriptions: true})
  let temp_one = (subscriptionsSetting[SUB_TEMPLATE_ID.temp_one] && subscriptionsSetting[SUB_TEMPLATE_ID.temp_one] !== 'accept') ? true : false
  let temp_two = (subscriptionsSetting[SUB_TEMPLATE_ID.temp_two] && subscriptionsSetting[SUB_TEMPLATE_ID.temp_two] !== 'accept') ? true : false

  if (!subscriptionsSetting.mainSwitch || temp_one || temp_two) {
      console.log('拒绝过,或未授权')
      // popup.is_setting = true
      Taro.showModal({
        title: '提示',
        content: '您之前拒绝过消息订阅,是否前往设置开启?',
        confirmText: '去设置',
        cancelText: '取消',
        success: async function (res) {
          if (res.confirm) {
            console.log('用户点击确定')
            Taro.openSetting({
              withSubscriptions: true,
              success: async (res) => {
                sendSome(type)

                let msg = {
                  [SUB_TEMPLATE_ID.temp_one]: '',
                  [SUB_TEMPLATE_ID.temp_two]: '',
                }
                
                // 上报给后端,订阅状态的接口
                你的逻辑
              }
            })
          }
        }
      })
      
      return
  }
  console.log('已授权', subscriptionsSetting,'向微信上报')
  Taro.requestSubscribeMessage({
  tmplIds:  [SUB_TEMPLATE_ID.temp_one, SUB_TEMPLATE_ID.temp_two],
  success: async(res) => {
    // 你的一些其它业务逻辑
    
    let msg = {
      [SUB_TEMPLATE_ID.temp_one]: res[SUB_TEMPLATE_ID.temp_one],
      [SUB_TEMPLATE_ID.temp_two]: res[SUB_TEMPLATE_ID.temp_two],
    }
     // 上报给后端,订阅状态的接口
       你的逻辑
  }
  })
}

文档直通车:开放接口 /设置 /wx.getSetting


3. 开发者调试时,点击过"总是。。。"之后,怎么才能再次触发弹框出现呢?
  • 在开发者工具里登录你的账号

  • "清除授权数据" 或者 "全部清除"

相关推荐
Yeats_Liao4 小时前
Go Web 编程快速入门 05 - 表单处理:urlencoded 与 multipart
前端·golang·iphone
飞翔的佩奇4 小时前
【完整源码+数据集+部署教程】【运动的&足球】足球场地区域图像分割系统源码&数据集全套:改进yolo11-RFAConv
前端·python·yolo·计算机视觉·数据集·yolo11·足球场地区域图像分割系统
拉不动的猪4 小时前
h5后台切换检测利用visibilitychange的缺点分析
前端·javascript·面试
桃子不吃李子4 小时前
nextTick的使用
前端·javascript·vue.js
萌新小码农‍5 小时前
SpringBoot+alibaba的easyexcel实现前端使用excel表格批量插入
前端·spring boot·excel
papership5 小时前
【入门级-算法-5、数值处理算法:高精度的减法】
算法·1024程序员节
韩立学长5 小时前
【开题答辩实录分享】以《租房小程序的设计和实现》为例进行答辩实录分享
java·spring boot·小程序
冰暮流星5 小时前
css3新增背景图片样式
前端·css·css3
從南走到北6 小时前
JAVA国际版一对一视频交友视频聊天系统源码支持H5 + APP
java·微信·微信小程序·小程序·音视频·交友