网站首页 > 知识剖析 正文
工作中遇到公众号发送客服消息,让用户点击选择。查看了微信开发者文档,发现“菜单消息” 可以满足,但是用户接收到的样式的确很难看,所以就想可不可以改变其样式来达到一种卡片式的消息。
先不说别的,先上微信客服消息---菜单消息文档如下:
1、开发文档
{
"touser": "OPENID",
"msgtype": "msgmenu",
"msgmenu": {
"head_content": "您对本次服务是否满意呢? "
"list": [
{
"id": "101",
"content": "满意"
},
{
"id": "102",
"content": "不满意"
}
],
"tail_content": "欢迎再次光临"
}
}
按照上述例子,用户会看到这样的菜单消息:
“您对本次服务是否满意呢?
满意
不满意”
其中,“满意”和“不满意”是可点击的,当用户点击后,微信会发送一条XML消息到开发者服务器,格式如下:
<xml>
<ToUserName><![CDATA[ToUser]]></ToUserName>
<FromUserName><![CDATA[FromUser]]></FromUserName>
<CreateTime>1500000000</CreateTime>
<MsgType><![CDATA[text]]></MsgType>
<Content><![CDATA[满意]]></Content>
<MsgId>1234567890123456</MsgId>
<bizmsgmenuid>101</bizmsgmenuid>
</xml>
XML参数说明:
参数 | 说明 |
ToUserName | 开发者帐号 |
FromUserName | 接收方帐号(OpenID) |
CreateTime | 消息创建时间戳 |
MsgType | Text |
Content | 点击的菜单名 |
MsgId | 消息ID |
bizmsgmenuid | 点击的菜单ID |
收到XML推送之后,开发者可以根据提取出来的bizmsgmenuid和Content识别出微信用户点击的是哪个菜单。
2、实现方式
本人在测试号调用此接口一直报40200的错误码 invalid account type, 在文档上找不到对应的错误码;后来在网上查阅资料才知道,此接口必须在正式的公众号才能调用成功。
备注:
msgmenuid:单击了哪个按钮对应的id(测试号以文本方式发送给微信服务器的话,返回的xml中不会有这个id,只有公众号才会有)
1、根据msgmenuid来判断用户点击了哪一个按钮,然后处理相关逻辑。
2、为了防止用户多次点击,可以后台返回一个随机数,用户点击的时候可以通过这个随机数判断是否已经处理过,如果为空或者随机数不是后台生成的则拒绝处理,发送客服提示消息。
要想达到卡片式的效果,超链接必须要加上微信地址weixin://bizmsgmenu服务器才会返回菜单按钮样式的xml。至于排版,可以通过\t 空格 \n换行 自行排版。
发送文本消息的内容如下
"检测到您正在和【张三】医生进行咨询尚未结束,是否要切换至【李四】医生咨询?\n\n"+"\t\t\t\t\t"+
"<a href=\"weixin://bizmsgmenu?msgmenucontent=切换&msgmenuid=10001\">切换</a>"+
"\t\t\t\t\t\t\t\t\t\t\t\t\t"+
"<a href=\"weixin://bizmsgmenu?msgmenucontent=不切换&msgmenuid=10002\">不切换</a>\n"+
"\n快马健康!(本次消息有效时间为30分钟)"
效果图如下:
?
- 上一篇: 4.页面结构(页面结构元素)
- 下一篇: css3属性(transform)的一个css3动画小应用
猜你喜欢
- 2024-11-17 4.页面结构(页面结构元素)
- 2024-11-17 JavaScript代码的三种引入方式【操作演示】
- 2024-11-17 我们为什么要使用 href="javascript:void(0)"
- 2024-11-17 一、学爬虫前,你需要知道的爬虫常识
- 2024-11-17 我只用一个txt文档,就将公众号里面的所有文章列表提取出来
- 2024-11-17 码畜在工作中总结的知识点,记录一下
- 2024-11-17 04元素类型(元素种类总结)
- 2024-11-17 H5 nav元素的作用&应用场合(互联网应用与北斗系统在其中的作用)
- 2024-11-17 2024 年 PWA 无法与 Native 媲美的 7 个特性
- 2024-11-17 前端「移动端」常见知识点总结(前端移动端是什么)
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)