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

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

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

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

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

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

小程序通过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... 下发消息通知

  • 当某用户触发一定条件后,查询该用户是否具备通知资格,如果具备,就可以通过接口下发消息通知。
相关推荐
霸王蟹1 分钟前
el-table组件样式如何二次修改?
前端·javascript·vue.js·笔记·学习·前端框架
star010-1 小时前
一文学会HTML编程之视频+图文详解详析
前端·网络·网络安全·html·html5
star010-1 小时前
【视频+图文详解】HTML基础3-html常用标签
前端·css·网络安全·html·html5·学习方法
无限大.6 小时前
前端知识速记:节流与防抖
前端
十八朵郁金香7 小时前
【VUE案例练习】前端vue2+element-ui,后端nodo+express实现‘‘文件上传/删除‘‘功能
前端·javascript·vue.js
学问小小谢7 小时前
第26节课:内容安全策略(CSP)—构建安全网页的防御盾
运维·服务器·前端·网络·学习·安全
LCG元7 小时前
Vue.js组件开发-实现全屏图片文字缩放切换特效
前端·javascript·vue.js
还是鼠鼠8 小时前
图书管理系统 Axios 源码__新增图书
前端·javascript·vscode·ajax·前端框架·node.js·bootstrap
还是鼠鼠11 小时前
图书管理系统 Axios 源码 __删除图书功能
前端·javascript·vscode·ajax·前端框架·node.js·bootstrap
轻口味11 小时前
Vue.js `Suspense` 和异步组件加载
前端·javascript·vue.js