上一篇:接入指南
這部分是實現(xiàn)簡單的自動回復(fù),當(dāng)然也是很大一部分功能的實現(xiàn)基礎(chǔ),這里使用了圖靈機器人的接口。
效果圖如下:

當(dāng)然,這個機器人的效果如何不是我能管得了的事情了,類似圖靈機器人,我們還可以實現(xiàn)段子推送,快遞查詢等一系列功能,這里不一一實現(xiàn)了。
微信的消息處理
對于公眾平臺,每一次發(fā)消息相當(dāng)于發(fā)出一個post請求,但是需要注意的是不管是發(fā)出的請求還是收到的回復(fù),他的數(shù)據(jù)格式都是xml,但是nodejs本身無法處理xml,所以需要對xml數(shù)據(jù)進行處理。
仍然使用的是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就是處理好的數(shù)據(jù)了。
一般文本消息的格式如下所示:
<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是發(fā)送者的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設(shè)置為xml,返回一個xml的響應(yīng),那么公眾號就會相應(yīng)的回復(fù)一個消息,這里回復(fù)的消息是文本格式。(mac的微信一年沒更新了--)
|
新聞熱點
疑難解答