订阅消息实战教程

接入订阅消息

开发者可以在知晓推送页面进入订阅消息接入向导:接入向导

  • 前三步与接入微信类似,详情可查看微信小程序接入,在「接入 SDK」处需要填入 AppScret,AppSecret 用于开通模板消息服务,在小程序后台“设置 - 开发设置”中查看。

上报订阅状态上报订阅状态

上报订阅状态上报订阅状态

  • 根据引导进行上报订阅消息。

完成接入完成接入

  • 通过校验后即完成接入。

获取模板 ID

模板库模板库

选用模板库选用模板库

在模板库中搜索合适的模板,点击选用,选择需要的关键词后提交即可完成模板创建。

我的模板我的模板

在「我的模板」可以查看、添加和删除模板,在这里获取模板 ID。

获取下发权限

微信小程序提供了 wx.requestSubscribeMessage 接口来发起申请订阅权限界面。

上报订阅状态的接口

知晓云提供了 wx.BaaS.subscribeMessage(options) SDK 来进行收集订阅状态。

参数说明

参数类型必填说明
subscriptionSubscription[]参数列表

Subscription

参数类型必填说明
template_idString模板 ID
subscription_typeString订阅类型,目前只支持 once(一次性订阅)

用户发生点击行为或者发起支付回调后,调起订阅消息界面,通过 SDK 上报订阅状态。

示例代码

在函数内我们会调用微信 API wx.requestSubscribeMessage 申请发送订阅权限,弹窗出来后,我们会收到 success 回调,当用户在弹窗同意订阅后,即上报订阅结果为 accept ,将订阅的 template_id (模板 ID)和 subscription_type(订阅类型)存入 subscription 数组中,最后在调用 SDK 进行上报即可。

  1. wx.requestSubscribeMessage({
  2. tmplIds: [this.data.id],
  3. success: (res) => {
  4. let subscription = []
  5. if (res[this.data.id] === 'accept') {
  6. subscription.push({
  7. template_id: this.data.id,
  8. subscription_type: 'once',
  9. })
  10. }
  11. wx.BaaS.subscribeMessage({subscription}).then(res => {
  12. // success
  13. }, err => {
  14. // fail
  15. })
  16. },
  17. })
  • 目前只支持一次性订阅
  • 需要上报订阅结果为 accept 的模版 ID

订阅记录订阅记录

在「订阅记录」查看和操作收集到的订阅记录

发送订阅消息

  • 在线发送
  • 通过触发器触发
  • 云函数发送

在线发送

在线发送在线发送

通过在「订阅消息」给用户在线发送订阅消息。填入所需的内容,可以选择立即发送或定时发送。

智能过滤

智能过滤智能过滤

在筛选目标用户时,建议开发者使用智能过滤服务,以保证模板消息的触达率和转化率。

通过触发器触发

创建触发器

创建触发器点击「引擎」-「触发器」即可创建新的触发器。

触发类型:即触发源,每个触发器都只能选定一种触发类型,不同的触发类型可执行的动作选项也不一样。

设置条件

设置条件设置条件

当选定触发类型后,开发者需要指定触发条件来触发后续动作的执行,触发条件与触发类型一一相关,当满足触发条件的时候即可触发该触发器。

设置动作

设置动作设置动作

动作类型选择「发送订阅消息」,与在线发送类似,填入相关内容,通过模板校验后即可完成触发器创建。如果所示,updated_at 存的是字符串,可以使用 {{updated_at | date:"Y年m月d日 H:i"}} 这种 filter 形式进行转换。另外可以点击「添加动作」继续设置动作。

更多内容可查看知晓云-触发器教程

通过云函数发送

创建云函数

创建云函数创建云函数

通过「引擎」-「云函数」-「添加」即可完成云函数的创建。

示例代码

示例代码示例代码

编写完云函数后点击保存即完成云函数的修改。

通过触发器搭配云函数使用

触发器触发器

当需要发送的订阅消息逻辑较为复杂时,可以通过编写云函数进行触发。

详情可参考开发文档中的章节《使用云函数发送订阅消息

注意事项

发送订阅消息必须严格按照「订阅消息参数值内容限制说明」来进行填写,「在线发送」以及「触发器」设置动作中已有模板对应的参数值限制。如参数值错误,将导致发送失败,发送详情可在「知晓推送」-「日志」处查看。