摘要:上一篇接入指南這部分是實現簡單的自動回復,當然也是很大一部分功能的實現基礎,這里使用了圖靈機器人的接口。的微信一年沒更新了如上圖,發送消息則會回復一個內容一樣的消息,一個簡單的自動回復就實現了。
上一篇:接入指南
這部分是實現簡單的自動回復,當然也是很大一部分功能的實現基礎,這里使用了圖靈機器人的接口。
效果圖如下:
當然,這個機器人的效果如何不是我能管得了的事情了,類似圖靈機器人,我們還可以實現段子推送,快遞查詢等一系列功能,這里不一一實現了。
微信的消息處理對于公眾平臺,每一次發消息相當于發出一個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?
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/79874.html
摘要:我之前的文章微信程序開發系列教程一開發環境搭建介紹了微信開發環境的搭建,這篇文章我們就來一步步開發一些具體的功能。下文將該應用稱為消息服務器。我們首先用的獲得一個對象當有微信用戶關注您的公眾號時,微信平臺會發送一個請求到您的消息服務器。 我之前的文章?微信程序開發系列教程(一)開發環境搭建?介紹了微信開發環境的搭建,這篇文章我們就來一步步開發一些具體的功能。 功能需求:當有微信用戶關注...
摘要:沒有耐心閱讀的同學,可以直接前往學習全棧最后一公里。我下面會羅列一些,我自己錄制過的一些項目,或者其他的我覺得可以按照這個路線繼續深入學習的項目資源。 showImg(https://segmentfault.com/img/bVMlke?w=833&h=410); 本文技術軟文,閱讀需謹慎,長約 7000 字,通讀需 5 分鐘 大家好,我是 Scott,本文通過提供給大家學習的方法,...
摘要:我的前一篇文章微信程序開發系列教程一開發環境搭建已經介紹了微信服務器的開發環境搭建。本文作為開發系列的第二篇文章,介紹如何給您的微信訂閱號開發一個最簡單的問答服務,非常好玩。 我的前一篇文章微信程序開發系列教程(一)開發環境搭建?已經介紹了微信服務器的開發環境搭建。本文作為開發系列的第二篇文章,介紹如何給您的微信訂閱號開發一個最簡單的問答服務,非常好玩。 這個系列的完整代碼在我的git...
閱讀 1221·2021-11-24 09:39
閱讀 2142·2021-11-22 13:54
閱讀 2136·2021-09-08 10:45
閱讀 1463·2021-08-09 13:43
閱讀 2995·2019-08-30 15:52
閱讀 3095·2019-08-29 15:38
閱讀 2857·2019-08-26 13:44
閱讀 3064·2019-08-26 13:30