1、订阅消息
其实如果用过模板消息的话,改用订阅消息挺简单的,看一下官方文档稍加摸索就能使用。
但是对于那些第一次用的萌新来说,可能会遇到各种各样的坑,所以我会具体的说一下实现的过程,有经验的可以直接翻到文章底部查看 Demo。
虽然如此,但是更详细的参数描述还是需要去看官方文档,传送门:
https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/subscribe-message.html
2、准备工作
首先是要获取template_id,也就是模板 ID。
这个在小程序后台的公共模板库找到适用的模板选用,之后到我的模板中复制系统分配的模板 ID即可。如果没找到合适的,就需要自己申请模板,3 - 7 天审核期。
然后就是小程序的 AppId 和 AppSecret,获取方式在小程序后台的开发功能中找到开发设置,保存 ID 和秘钥。
这里需要注意的是AppSecret只有在第一次生成的时候会显示,之后不再明文显示,这个需要开发者自己保存好,如果泄露或者忘记密匙重置即可。
至于 openid 的获取这里就不做具体说明了。
3、授权接收
发送前需要接受者授权接收该类订阅消息,否则订阅消息是无法下发,代码很简单,调用官方的订阅接口:
wx.requestSubscribeMessage({ tmplIds: ['template_id'], // 此处可填写多个模板 ID,但低版本微信不兼容只能授权一个 success (res) { console.log('已授权接收订阅消息') } })
拉起的授权框是这样的,但是截止发文之前,开发者工具是无法调用接口,只能在真机上运行,无奈。
4、下发订阅消息
下发消息调用subscribeMessage.send ,分为云调用和 https 调用,云调用比较简单,免去了 access_token 的获取:
const cloud = require('wx-server-sdk') cloud.init() exports.main = async (event, context) => { try { const result = await cloud.openapi.subscribeMessage.send({ touser: 'OPENID', page: 'index', data: { name3: { value: '我是玖柒后' }, thing4: { value: 'Hello World!' }, phrase1: { value: "发送成功!" }, date5: { value: "发送成功!" }, thing2: { value: "1024 身体健康!" } }, templateId: 'TEMPLATE_ID' }) console.log(result) return result } catch (err) { console.log(err) return err } }
内容版权声明:除非注明,否则皆为本站原创文章。