微信小程序实现一次性消息订阅

微信小程序的消息订阅分为以下三种

  • 一次性消息订阅
    • 用户订阅一次,就拥有一次向用户下发通知的机会,次数可以累加。这也是目前绝大多数小程序可以实现的消息订阅方案。
  • 长期性消息订阅
    • 用户订阅一次,就可以一直向用户推送信息。微信考虑到用户使用感受,目前绝大多数小程序类目都不支持开通长期消息订阅。目前长期性订阅消息仅向政务民生、医疗、交通、金融、教育等线下公共服务开放。
  • 设备消息订阅
    • 设备订阅需要有终端的支持,例如:扫地机器人、摄像头等设备。其属于长期消息订阅的一种。

如何实现小程序一次性消息订阅?

登录小程序后台,开通消息订阅

创建消息模板并提交。注意:创建模板提交审核,尽量提前创建。

小程序通过wx.requestSubscribeMessage唤起订阅弹框,提交后该微信用户就具备一次收到该模板通知的机会。

详细的API文档请参考 requestSubscribeMessage文档

scss 复制代码
wx.requestSubscribeMessage({
  tmplIds: [模板ID],
  success (res) {
    if(res[模板ID] === 'accept'){
        // 订阅了该消息模板
        // 将openid传给业务服务端,通知后端该openid、UID具备了一次消息通知额度,后端可以根据前端传的次数来进行累加
    }
    
    if(res[模板ID] === 'reject'){
        // 拒绝了该消息模板
    }
    
  }
})

注意事项:

  • 小程序一次性消息订阅的弹框唤起时,模板默认不选中,总是保持以上选择默认选中。该小程序默认行为,无法修改。

  • 订阅弹框唤起时,勾选总是保持以上选择,并不是长期订阅。而是下次再次执行唤起订阅弹框代码时,不再弹框,直接拿默认值触发允许行为。 默认值可通过小程序设置里进行更改,一旦勾选总是保持以上选择,该小程序永远不再进行该消息模板的提示弹框。

服务端通过api.weixin.qq.com/cgi-bin/mes... 下发消息通知

  • 当某用户触发一定条件后,查询该用户是否具备通知资格,如果具备,就可以通过接口下发消息通知。
相关推荐
前端小巷子9 分钟前
Webpack 5模块联邦
前端·javascript·面试
玲小珑12 分钟前
Next.js 教程系列(十九)图像优化:next/image 与高级技巧
前端·next.js
晓得迷路了12 分钟前
栗子前端技术周刊第 91 期 - 新版 React Compiler 文档、2025 HTML 状态调查、Bun v1.2.19...
前端·javascript·react.js
江城开朗的豌豆19 分钟前
Vue和React中的key:为什么列表渲染必须加这玩意儿?
前端·vue.js·面试
江城开朗的豌豆24 分钟前
前端路由傻傻分不清?route和router的区别,看完这篇别再搞混了!
前端·javascript·vue.js
pengzhuofan27 分钟前
Web开发系列-第0章 Web介绍
前端
小鱼人爱编程36 分钟前
Java基石--反射让你直捣黄龙
前端·spring boot·后端
JosieBook2 小时前
【web应用】如何进行前后端调试Debug? + 前端JavaScript调试Debug?
前端·chrome·debug
LBJ辉2 小时前
2. Webpack 高级配置
前端·javascript·webpack
灵感__idea9 小时前
JavaScript高级程序设计(第5版):好的编程就是掌控感
前端·javascript·程序员