微信小程序下架了模板消息功能,取而代之的是订阅消息功能。这个订阅消息目前又分为「一次性订阅」和「永久订阅」。项目里最近需要用到这个功能,但是有很多坑需要注意的。
首先
可以看下文章底部的官方文档使用api。在使用的时候注意一下几个点。(我自己一开始用的时候真的被坑,找了好久没有答案)
1. 真机调试
(1) 触发用户订阅,微信小程序提供的api是: wx.requestSubscribeMessage
,用户发生点击行为或者发起支付回调后,才可以调起订阅消息界面。一开始我在小程序的onShow
方法里面调用的,页面没任何反应。后来页面上加了一个按钮,点击调用这个api,授权的页面才出现。
(2) 小程序开发工具里预览触发用户订阅,基础库版低的会提示:requestSubscribeMessage:fail 开发者工具暂时不支持此 API 调试, 请使用真机进行开发
。但基础库高一些的也不会在开发开发工具里显示授权的页面,只会出现一下的弹框。(一开始不知道,一直以为api用错了,实际上却是本地预览在小程序开发工具里和手机上显示的不同)
正常的UI见第二点的图。
简而言之: 就是只能在本地没法调试。只能用真机调试。
2. 长期订阅的误区
订阅消息包括两种:
(1)一次性订阅消息
一次性订阅消息用于解决用户使用小程序后,后续服务环节的通知问题。用户自主订阅后,开发者可不限时间地下发一条对应的服务消息;每条消息可单独订阅或退订。
(2)长期订阅消息
一次性订阅消息可满足小程序的大部分服务场景需求,但线下公共服务领域存在一次性订阅无法满足的场景,如航班延误,需根据航班实时动态来多次发送消息提醒。为便于服务,我们提供了长期性订阅消息,用户订阅一次后,开发者可长期下发多条消息。
选择了允许并且[总是保持以上选择,不再询问]选项,并不是说就可以在一直推送订阅消息(误以为的长期订阅)。而是订阅一次以后,以后再调用获取用户订阅的api,不会再弹出获取订阅的弹框(也就是上图的UI)。因为模版使用的是 一次性订阅
的模版。所以勾选和不勾选 总是保持
唯一的区别就是每次触发订阅的时候会不会弹授权窗口而已。
而长期订阅
,是可以一直推送消息。但是长期订阅门槛太高了,目前长期性订阅消息仅向政务民生、医疗、交通、金融、教育等线下公共服务开放,后期将逐步支持到其他线下公共服务业务。
3. 订阅次数
微信不会为开发者保存订阅次数,需要前后端通过接口在后台记录用户触发的次数。
wx.requestSubscribeMessage({
tmplIds: ["模板id1","模板id2"],
success: (res) => {
//成功 ('Gzq8zw6MykOkcWc-88_d9EdaQyjI8344Eqm96UT3JxQ': 消息模版Id)
if(res['Gzq8zw6MykOkcWc-88_d9EdaQyjI8344Eqm96UT3JxQ'] === 'accept') {
//接口交互, 记录订阅次数
}
},
fail(err) {
//失败
console.error(err);
}
}
超过次数调用接口下发订阅消息会返回失败:errMsg: "user refuse to accept the msg hint: [kvSpTa08704119]"
最后:
消息模版存在的问题:
1.部分开发者在用户无预期或未进行服务的情况下发送与用户无关的消息,对用户产生了骚扰。2. 模板消息需在用户访问小程序后的 7 天内下发,不能满足部分业务的时间要求。
为了解决模板消息存在的缺陷,订阅消息虽然把订阅的授权的交给了用户且开发者可不限时间地下发一条对应的服务消息,但是也带来了其他问题。比如, 一次性订阅只能收到一次,要想推送多条消息让用户接收到, 需要操作多次授权。如果不是刚需用户可能会首次就拒绝了这个服务,要想重新获取授权,需要用户自己打开小程序设置里去配置,颇为麻烦,小程序没有提供更简便的方法去唤起。
网友评论