摘要:上一篇接入指南这部分是实现简单的自动回复,当然也是很大一部分功能的实现基础,这里使用了图灵机器人的接口。的微信一年没更新了如上图,发送消息则会回复一个内容一样的消息,一个简单的自动回复就实现了。
上一篇:接入指南
这部分是实现简单的自动回复,当然也是很大一部分功能的实现基础,这里使用了图灵机器人的接口。
效果图如下:
当然,这个机器人的效果如何不是我能管得了的事情了,类似图灵机器人,我们还可以实现段子推送,快递查询等一系列功能,这里不一一实现了。
微信的消息处理对于公众平台,每一次发消息相当于发出一个post请求,但是需要注意的是不管是发出的请求还是收到的回复,他的数据格式都是xml,但是nodejs本身无法处理xml,所以需要对xml数据进行处理。
仍然使用的是body-parser这个库,但是需要引入body-parser-xml:
//解析xml app.use(bodyParser.xml({ limit: "1MB", // Reject payload bigger than 1 MB xmlParseOptions: { normalize: true, // Trim whitespace inside text nodes normalizeTags: true, // Transform tags to lowercase explicitArray: false // Only put nodes in array if >1 } }));
这样req.body.xml就是处理好的数据了。
一般文本消息的格式如下所示:
1348831860 1234567890123456
其中ToUserName是接受者的openid,FromUserName是发送者的openid,CreateTime就是一个整型的时间戳。MsgType就是消息类型,一般有文本(text),图片(image),语音(voice),视频(video),小视频(shortvideo),地理位置(location)以及链接消息(link)。下面就以文本消息为例进行编码。
router.post("/", function (req, res) { res.writeHead(200, {"Content-Type": "application/xml"}); var data = req.body.xml; var resMsg = "" + " "; res.end(resMsg); });" + " " + " " + parseInt(new Date().valueOf() / 1000) + " " + "" + " " + "
只需要将header的content-type设置为xml,返回一个xml的响应,那么公众号就会相应的回复一个消息,这里回复的消息是文本格式。(mac的微信一年没更新了--)
如上图,发送消息则会回复一个内容一样的消息,一个简单的自动回复就实现了。
这个接口的使用十分简单,get请求链接,记得带上apikey的头,然后就会返回响应的内容。我这里请求使用的是nodejs request库。
const request = require("request"); const config = require("../../config"); function getTuringResponse(info) { if(typeof info !== "string") { info = info.toString(); } var options = { method:"GET", url: "http://apis.baidu.com/turing/turing/turing?key=879a6cb3afb84dbf4fc84a1df2ab7319&info="+info, headers: { "apikey": config.turingKey } }; return new Promise((resolve, reject) => { request(options, function (err, res, body) { if (res) { resolve(body); } else { reject(err); } }); }) } module.exports = getTuringResponse;
使用promise处理异步返回的结果,避免多次回调,记得把apikey设置为header内容。
公众号机器人好了,上面是二者分开的讲的,如果看到这应该知道一个聊天机器人的实现是非常简单的了。就是将接口响应的内容返回给用户(?如果不是非要自己实现聊天机器人的话。。。),后台这里也就相当于一个跳板。
turingRobot.js
const request = require("request"); const config = require("../../config"); function getTuringResponse(info) { if(typeof info !== "string") { info = info.toString(); } var options = { method:"GET", url: "http://apis.baidu.com/turing/turing/turing?key=879a6cb3afb84dbf4fc84a1df2ab7319&info="+info, headers: { "apikey": config.turingKey } }; return new Promise((resolve, reject) => { request(options, function (err, res, body) { if (res) { resolve(body); } else { reject(err); } }); }) } module.exports = getTuringResponse;
这部分代码很简单了,就是将图灵机器人的接口响应消息返回出来。下面要做的就是将消息返回给用户,这里有一点需要注意的是对于发出的响应,该接口不能直接响应中文字符串,需要进行urlencode。
//autoReply.js const request = require("request"); function autoReply(requestData, info) { switch (requestData.msgtype) { case "text": var resMsg = "" + " "; break; } return resMsg; } module.exports = autoReply;" + " " + " " + parseInt(new Date().valueOf() / 1000) + " " + "" + " " + "
自动回复的模块,主要是返回一个xml字符串,方便发送给用户。
//weixin.js router.post("/", function (req, res) { res.writeHead(200, {"Content-Type": "application/xml"}); var content = req.body.xml.content; turingRobot(encodeURI(content)).then(function (data) { var response = JSON.parse(data); var resMsg = autoReply(req.body.xml, response.text); res.end(resMsg); }) });
好,这下算是完成机器人聊天的功能了。只要将代码部署到leancloud里,就算是成功了。
github地址奉上:https://github.com/xiadd/shorthand 欢迎star?
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/79874.html
摘要:我之前的文章微信程序开发系列教程一开发环境搭建介绍了微信开发环境的搭建,这篇文章我们就来一步步开发一些具体的功能。下文将该应用称为消息服务器。我们首先用的获得一个对象当有微信用户关注您的公众号时,微信平台会发送一个请求到您的消息服务器。 我之前的文章 微信程序开发系列教程(一)开发环境搭建 介绍了微信开发环境的搭建,这篇文章我们就来一步步开发一些具体的功能。 功能需求:当有微信用户关注...
摘要:没有耐心阅读的同学,可以直接前往学习全栈最后一公里。我下面会罗列一些,我自己录制过的一些项目,或者其他的我觉得可以按照这个路线继续深入学习的项目资源。 showImg(https://segmentfault.com/img/bVMlke?w=833&h=410); 本文技术软文,阅读需谨慎,长约 7000 字,通读需 5 分钟 大家好,我是 Scott,本文通过提供给大家学习的方法,...
摘要:我的前一篇文章微信程序开发系列教程一开发环境搭建已经介绍了微信服务器的开发环境搭建。本文作为开发系列的第二篇文章,介绍如何给您的微信订阅号开发一个最简单的问答服务,非常好玩。 我的前一篇文章微信程序开发系列教程(一)开发环境搭建 已经介绍了微信服务器的开发环境搭建。本文作为开发系列的第二篇文章,介绍如何给您的微信订阅号开发一个最简单的问答服务,非常好玩。 这个系列的完整代码在我的git...
阅读 1180·2021-11-24 09:39
阅读 2097·2021-11-22 13:54
阅读 2027·2021-09-08 10:45
阅读 1414·2021-08-09 13:43
阅读 2958·2019-08-30 15:52
阅读 3049·2019-08-29 15:38
阅读 2820·2019-08-26 13:44
阅读 3016·2019-08-26 13:30