微信小程序想要对接独立在线客服系统,除了使用小程序消息推送接口外,还可以使用webview嵌入的形式嵌入聊天链接。
但是,使用webview嵌入的形式,当用户离开页面以后,就收不到客服回复的消息了
所以,我们需要当用户离开聊天页面后,客服回复消息,使用小程序的订阅模板来进行通知。
我们前往小程序后台,去开启一下订阅消息,并且选用一个模板。
在公共模板库里搜索一下,选用“咨询回复通知”
配置一下字段,我们就需要三个字段就可以了,分别是,“回复内容” “回复时间” “回复者”
这样会得到模板ID,后面我们会通过这个模板ID进行发送
现在,我们去小程序端,增加一下订阅事件
在小程序端向用户发起消息请求,需要注意请求需要放在触发事件中,不能凭空(onload、onshow或者其他情况)触发。
页面xml
<button bindtap="sendreq">开始订阅</button>
页面js
const app = getApp()
Page({
sendreq(){
wx.requestSubscribeMessage({
tmplIds: ['这里替换成你的模板ID'],
success (res) {
console.log(res)
// res包含模板id,值包括'accept'、'reject'、'ban'、'filter'。
// 'accept'表示用户同意订阅该条id对应的模板消息
// 'reject'表示用户拒绝订阅该条id对应的模板消息
// 'ban'表示已被后台封禁
// 'filter'表示该模板因为模板标题同名被后台过滤。
}
})
}
})
只有这样订阅过以后,才能给这个用户发送模板消息
我们后端发送模板消息的golang参考代码如下:
import (
"github.com/silenceper/wechat/v2"
offConfigMini "github.com/silenceper/wechat/v2/miniprogram/config"
subscribeMsg "github.com/silenceper/wechat/v2/miniprogram/subscribe"
"kefu/tools"
"log"
)
cfg := &offConfigMini.Config{
AppID: "AppID",
AppSecret: "AppSecret",
Cache: memory,
}
wc := wechat.NewWechat()
mini := wc.GetMiniProgram(cfg)
subscribe := mini.GetSubscribe()
data := make(map[string]*subscribeMsg.DataItem, 0)
data["thing1"] = &subscribeMsg.DataItem{Value: "测试", Color: "#000"}
data["time2"] = &subscribeMsg.DataItem{Value: tools.GetNowTime(), Color: "#000"}
data["name3"] = &subscribeMsg.DataItem{Value: "客服", Color: "#000"}
msg := &subscribeMsg.Message{
ToUser: "okSbF5AhyVeyO-gK-Nj_nwoi2LQU",
TemplateID: "Hk0zWtbgl0aci6b0UIWSUBywYzaglNqkw0KhzkbEuN4",
Page: "/pages/index",
Data: data,
}
log.Printf("%+v \n", msg)
err := subscribe.Send(msg)
if err != nil {
log.Println("发送小程序订阅消息失败:", err)
}
现在其实已经就能发送模板消息了
稍后,会开发客服系统后台,详细配置硬编码的字段。