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

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

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

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

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

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

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

  • 当某用户触发一定条件后,查询该用户是否具备通知资格,如果具备,就可以通过接口下发消息通知。
相关推荐
颜颜yan_3 分钟前
DevUI + Vue 3 入门实战教程:从零构建AI对话应用
前端·vue.js·人工智能
国服第二切图仔1 小时前
DevUI Design中后台产品开源前端解决方案之Carousel 走马灯组件使用指南
前端·开源
无限大61 小时前
为什么浏览器能看懂网页代码?——从HTML到渲染引擎的奇幻之旅
前端
福尔摩斯张1 小时前
Linux信号捕捉特性详解:从基础到高级实践(超详细)
linux·运维·服务器·c语言·前端·驱动开发·microsoft
2401_860319521 小时前
DevUI组件库实战:从入门到企业级应用的深度探索 ,如何快速安装DevUI
前端·前端框架
cc蒲公英2 小时前
javascript有哪些内置对象
java·前端·javascript
zhangwenwu的前端小站2 小时前
vue 对接 Dify 官方 SSE 流式响应
前端·javascript·vue.js
王林不想说话2 小时前
受控/非受控组件分析
前端·react.js·typescript
_杨瀚博2 小时前
VUE中使用AXIOS包装API代理
前端
张有志2 小时前
基于 Body 滚动的虚拟滚动组件技术实现
前端·react.js