国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

nodejs微信開發之自動回復的實現

2024-05-06 16:49:08
字體:
來源:轉載
供稿:網友

上一篇:接入指南

這部分是實現簡單的自動回復,當然也是很大一部分功能的實現基礎,這里使用了圖靈機器人的接口。

效果圖如下:

nodejs,微信開發,自動回復

當然,這個機器人的效果如何不是我能管得了的事情了,類似圖靈機器人,我們還可以實現段子推送,快遞查詢等一系列功能,這里不一一實現了。

微信的消息處理

對于公眾平臺,每一次發消息相當于發出一個post請求,但是需要注意的是不管是發出的請求還是收到的回復,他的數據格式都是xml,但是nodejs本身無法處理xml,所以需要對xml數據進行處理。
仍然使用的是body-parser這個庫,但是需要引入body-parser-xml:

//解析xmlapp.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就是處理好的數據了。

一般文本消息的格式如下所示:

<xml> <ToUserName><![CDATA[toUser]]></ToUserName> <FromUserName><![CDATA[fromUser]]></FromUserName> <CreateTime>1348831860</CreateTime> <MsgType><![CDATA[text]]></MsgType> <Content><![CDATA[this is a test]]></Content> <MsgId>1234567890123456</MsgId> </xml>

其中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 = '<xml>' +  '<ToUserName><![CDATA[' + data.fromusername + ']]></ToUserName>' +  '<FromUserName><![CDATA[' + data.tousername + ']]></FromUserName>' +  '<CreateTime>' + parseInt(new Date().valueOf() / 1000) + '</CreateTime>' +  '<MsgType><![CDATA[text]]></MsgType>' +  '<Content><![CDATA['+data.content+']]></Content>' +  '</xml>'; res.end(resMsg);});

只需要將header的content-type設置為xml,返回一個xml的響應,那么公眾號就會相應的回復一個消息,這里回復的消息是文本格式。(mac的微信一年沒更新了--)

nodejs,微信開發,自動回復

如上圖,發送消息則會回復一個內容一樣的消息,一個簡單的自動回復就實現了。

圖靈機器人

這個接口的使用十分簡單,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.jsconst request = require('request');function autoReply(requestData, info) { switch (requestData.msgtype) {  case 'text':   var resMsg = '<xml>' +    '<ToUserName><![CDATA[' + requestData.fromusername + ']]></ToUserName>' +    '<FromUserName><![CDATA[' + requestData.tousername + ']]></FromUserName>' +    '<CreateTime>' + parseInt(new Date().valueOf() / 1000) + '</CreateTime>' +    '<MsgType><![CDATA[text]]></MsgType>' +    '<Content><![CDATA['+info+']]></Content>' +    '</xml>';   break; } return resMsg;}module.exports = autoReply;

自動回復的模塊,主要是返回一個xml字符串,方便發送給用戶。

//weixin.jsrouter.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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 临洮县| 武宁县| 遵化市| 桃园县| 漯河市| 永年县| 和田市| 开封市| 张家口市| 库尔勒市| 连城县| 且末县| 彝良县| 辽源市| 鹤壁市| 四平市| 澎湖县| 城步| 漳平市| 武城县| 怀化市| 义马市| 台东县| 米林县| 黄石市| 浑源县| 怀仁县| 德清县| 工布江达县| 米泉市| 皮山县| 罗甸县| 扶风县| 贡觉县| 墨江| 蒲江县| 崇文区| 峨边| 五大连池市| 黔西| 红桥区|