【Node.js】实现微信小程序订阅消息推送功能

时间:2022-12-13 10:54:11

实战项目名称:实现微信小程序订阅消息通知


一、实战步骤

1. 登录微信小程序管理端,添加订阅消息模板

登录后,在功能 > 订阅消息 > 公共模板库 ,然后去添加你需要的模板

  • 注意下图红线部分的内容,下一步用的到
    【Node.js】实现微信小程序订阅消息推送功能

2. 定义好需要发送的消息

// 示例代码,对应上方红线的内容
let messages =
        {
            touser: '********************',//给某用户推送的openid,这个得你获取到用户的openid,才可以进行推送
            template_id: 'xxxxxxxxxxxxxxxxxxxxxxx', //订阅模板id
            data: {
                character_string1: {
                    value: 'order_87689176582576'// 订单号
                },
                amount13: {
                    value: '9999.00' //订单金额
                },
                amount4: {
                    value: '9999.00' //支付金额
                }
            }
        }

3.获取小程序的access_token

// config.app.appid 对应小程序的appid
// config.app.secret 对应小程序的秘钥
 const url = `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${config.app.appid}&secret=${config.app.secret}`
        const responses = await axios.get(url)
            .then(function (response) {
                // 处理成功情况
                return response.data
            })
            .catch(function (error) {
                // 处理错误情况
                console.log(error);
            })

4. 发起请求,向用户推送消息

这里有用到request插件,记得 npm install request 或者 yarn add request;

  • 然后记得引用就好了 import request from 'request'
// responses.access_token就是上一步我们拿到的access_token

 const urls = `https://api.weixin.qq.com/cgi-bin/message/subscribe/send?access_token=${responses.access_token}`
       
        const options = {
            method: 'post',
            url: urls,
            json: messages //第二步定于的消息内容
        }
        request(options, function (err, res, body) {
            if (err) {
                console.log(err)
            } else {
                if (body.errcode !== 0) {
                    console.log(body)
                }
            }
        })

4. 小程序端添加接收订阅消息的按钮

// 点击后,会弹窗一个授权窗口,同意之后就可以进行测试订阅消息推送了

uni.requestSubscribeMessage({
					// 模板id:可以在微信公众平台 -> 功能 -> 订阅信息进行选择
					tmplIds: ['3pDRw50ype8nrg8ntqeiBnhFPzQ_kpADrPWsFhwhtNI'],
					success: res => {
						console.log(res)
					},
					fail: e => {
						console.log(e)
					}
				})

二、完整源代码

 async startToast(_, { id }) {

        let messages =
        {
            touser: '********************',//给某用户推送的openid
            template_id: 'xxxxxxxxxxxxxxxxxx',//订阅模板id(上面提到的)
            data: {
                character_string1: {
                    value: 'order_87689176582576'// 订单号
                },
                amount13: {
                    value: '9999.00' //售后单号
                },
                amount4: {
                    value: '9999.00' //退款时间
                }
            }
        }

        const url = `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${config.app.appid}&secret=${config.app.secret}`
        const responses = await axios.get(url)
            .then(function (response) {
                // 处理成功情况
                return response.data
            })
            .catch(function (error) {
                // 处理错误情况
                console.log(error);
            })
        // console.log(responses)
        const urls = `https://api.weixin.qq.com/cgi-bin/message/subscribe/send?access_token=${responses.access_token}`
        // console.log(urls)
        const options = {
            method: 'post',
            url: urls,
            json: messages
        }
        request(options, function (err, res, body) {
            if (err) {
                console.log(err)
            } else {
                if (body.errcode !== 0) {
                    console.log(body)
                }
            }
        })
    },


三. 需要注意的地方

    1. 一次订阅对应一次消息推送,目前没有长期订阅的方案
    1. 小程序端和node.js后端中的模板ID注意一定要一致,不然推送不了