微信小程序订阅消息

微信小程序,总会有订阅消息功能,到某个时间点时,自动为用户推送消息,后台推送消息的前提是,用户已允许推送消息,可是用户订阅时可以选择是订阅一次,还是保持以上选择,不再询问,
需要注意的是,如果点击了总是保持以上选择不再询问,将不会再弹出提示框,但是一定要再次发送订阅消息,不然后端是无法判断的

    wx.getSetting({
      withSubscriptions: true,
      success: function (res) {
        if (res.subscriptionsSetting.mainSwitch) {
          if (res.subscriptionsSetting.itemSettings && res.subscriptionsSetting.itemSettings != 'undefined') { // 用户同意总是保持是否推送消息的选择, 这里表示以后不会再拉起推送消息的授权 
            let moIdState = res.subscriptionsSetting.itemSettings && res.subscriptionsSetting.itemSettings.'消息模板id';
            // 用户同意的消息模板id
            if (moIdState === 'accept') {
              self.requestSubscribeMessage()
            } else if (moIdState === 'reject') {

            } else if (moIdState === 'ban') {} else {}
          } else {
            wx.showModal({
              title: '提示',
              content: '是否允许接收消息提醒',
              success(res) {
                if (res.confirm) {
                  wx.setStorageSync("hasAcceptMessage", 1)
                  // subMessage.getGuestTemplateIds()
                  self.requestSubscribeMessage()
                }
              }
            })
          }
        }
      },
      fail: function (error) {
        console.log(error, "errror+++++++++++")
      }
    })
    //监听用户点击了允许还是拒绝
    requestSubscribeMessage() {
	    let result = wx.requestSubscribeMessage({
	      tmplIds: '消息模板id'
	    })
	    if (result["MBdGe93b1r3hfb8i_WziD2cnAos-ZdHq0QKl_-bLg6s"] == 'accept') {
	
	      console.log("接受了不再询问")
	    } else if (result["MBdGe93b1r3hfb8i_WziD2cnAos-ZdHq0QKl_-bLg6s"] == 'reject') {
	      console.log("出错了reject")
	    }
  },
### 微信小程序实现订阅消息功能 #### 启用并配置消息推送 为了使微信小程序能够发送订阅消息,需先完成一些准备工作。这包括但不限于准备小程序账号、搭建开发环境,并确保所使用的框架(如uniapp)和后端技术栈(如Spring Boot)都已就绪[^1]。 #### 订阅消息的工作流程 订阅消息的功能允许小程序向用户传递特定的信息,而这一过程依赖于微信的服务通知机制来最终触达用户设备。具体来说,当小程序希望传达某条信息时,它会将所需的数据连同目标用户的唯一标识一同提交给微信服务器;随后,由微信服务器负责验证这些信息的有效性和合法性,在确认无误之后再转发至对应的微信客户端上显示出来[^3]。 #### 开发指南概览 对于开发者而言,想要成功集成此特性,则需要遵循官方文档指导下的几个关键环节: - **后端部分**:构建接口用于组装待发送的消息体结构并向微信公众平台API发起调用来触发实际的通知动作。 ```javascript // 前端示例代码 (UniApp) wx.requestSubscribeMessage({ tmplIds: ['your_template_id'], success(res){ console.log('用户同意订阅', res); }, fail(err){ console.error('获取权限失败', err); } }); ``` ```java // 后端示例代码片段 (Spring Boot) @PostMapping("/sendTemplateMsg") public ResponseEntity<String> sendTemplateMsg(@RequestBody Map<String, String> params) { // 构建HTTP POST 请求... } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值