【小程序】消息订阅requestSubscribeMessage

现在企业主体的订阅消息是一次性的,由于公司需要多次发送消息,却又不符合长期性订阅消息条件,只能每次进行弹出授权。
在这里插入图片描述
在后台提供消息订阅id后,前端进行授权提示。以下代码适用于有长期性订阅服务id的企业或政府:

  // 司机 - 消息订阅
  requestMessage() {
    var _this = this
    var tmplIds = '***' // 用户同意的消息模板id
    // 这里是获取下发权限地方,根据官方文档,可以根据  wx.getSetting() 的 withSubscriptions   这个参数获取用户是否打开订阅消息总开关。后面我们需要获取用户是否同意总是同意消息推送。所以这里要给它设置为true 。
    wx.getSetting({
      withSubscriptions: true,   //  这里设置为true,下面才会返回mainSwitch
      success: function(res){   
        // 调起授权界面弹窗
        if (res.subscriptionsSetting.mainSwitch) {  // 用户打开了订阅消息总开关
          if (res.subscriptionsSetting.itemSettings != null) {   // 用户同意总是保持是否推送消息的选择, 这里表示以后不会再拉起推送消息的授权
            let moIdState = res.subscriptionsSetting.itemSettings[tmplIds];  // 用户同意的消息模板id
            if(moIdState === 'accept'){   
              console.log('接受了消息推送');

            }else if(moIdState === 'reject'){
              console.log("拒绝消息推送");

            }else if(moIdState === 'ban'){
              console.log("已被后台封禁");

            }
          }else {
            // 当用户没有点击 ’总是保持以上选择,不再询问‘  按钮。那每次执到这都会拉起授权弹窗
            wx.showModal({
              title: '提示',
              content:'请授权开通服务通知',
              showCancel: true,
              success: function (ress) {
                if (ress.confirm) { 
                  // console.log('用户点击确定')
                  wx.requestSubscribeMessage({   // 调起消息订阅界面
                    tmplIds: [tmplIds],
                    success (res) { 
                      console.log('订阅消息 成功 ');
                      console.log(res);
                    },
                    fail (er){
                      console.log("订阅消息 失败 ");
                      console.log(er);
                    }
                  })     
                        
                } else if (ress.cancel) {
                  // console.log('用户点击取消')
                }
              }
            })
          }
        }else {
          console.log('订阅消息未开启')
        }      
      },
      fail: function(error){
        console.log(error);
      }
    })
  },

普通企业只有一次性的订阅消息模板id,所以每次都要调用,不管是不是选择保持授权:

// 司机 - 消息订阅
  requestMessage() {
    var tmplIds = '***' // 用户同意的消息模板id
    // 这里是获取下发权限地方,根据官方文档,可以根据  wx.getSetting() 的 withSubscriptions   这个参数获取用户是否打开订阅消息总开关。后面我们需要获取用户是否同意总是同意消息推送。所以这里要给它设置为true 。
    wx.getSetting({
      withSubscriptions: true,   //  这里设置为true,下面才会返回mainSwitch
      success: function(res){  
        // 调起授权界面弹窗
        if (res.subscriptionsSetting.mainSwitch) {  // 用户打开了订阅消息总开关
          // 每次执到这都会拉起授权弹窗
          wx.showModal({
            title: '提示',
            content:'请授权开通服务通知',
            showCancel: true,
            success: function (ress) {
              if (ress.confirm) { 
                // console.log('用户点击确定')
                wx.requestSubscribeMessage({   // 调起消息订阅界面
                  tmplIds: [tmplIds],
                  success (res) { 
                    console.log('订阅消息 成功 ');
                    // console.log(res);
                  },
                  fail (er){
                    console.log("订阅消息 失败 ");
                    // console.log(er);
                  }
                })   
                      
              } else if (ress.cancel) {
                // console.log('用户点击取消')
              }
            }
          })
        }else {
          console.log('订阅消息未开启')
        }      
      },
      fail: function(error){
        console.log(error);
      }
    })
  },

目前所知的就这些,有错误的话欢迎告诉我进行补充纠正

支付宝小程序订阅消息插件requestSubscribeMessage是用于用户同意获取订阅消息的插件。当我们在开发小程序时,想要向用户发送订阅消息时,需要先通过该插件向用户申请订阅权限,并获取用户的同意。 然而,当我们在代码中调用requestSubscribeMessage方法时,有时会遇到"requestSubscribeMessage undefined"的问题。这个问题主要是由于以下几个可能的原因所致: 1. 更新支付宝开发者工具:如果你的支付宝开发者工具版本较旧,可能不支持requestSubscribeMessage方法。建议你更新支付宝开发者工具到最新版本,以确保支持该方法。 2. 检查支付宝基础库版本:requestSubscribeMessage方法在某些较旧的支付宝基础库版本中可能没有定义。你可以检查一下你的支付宝基础库版本,如果较旧的话,尝试升级到最新版本。 3. 检查方法名称拼写错误:请确保在代码中正确拼写方法名requestSubscribeMessage,并且大小写一致。有时候,拼写错误也会导致该方法未定义的问题。 4. 检查插件是否添加成功:在支付宝小程序开发中,如果没有成功添加requestSubscribeMessage插件,也会导致该方法未定义。请确认是否已经按照官方文档正确添加了该插件,并在app.json文件中进行了配置。 总之,如果你遇到了"requestSubscribeMessage undefined"的问题,可以尝试以上几个步骤来解决。如果问题仍然存在,建议查阅支付宝小程序官方文档或者与支付宝技术支持联系,获取更详细的帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值