我的消息bot api出错了。由于某种原因,它会在消息发送给某个用户时多次触发20个。我在节点上使用heroku。我不知道为什么这样做?任何帮助将非常感激。
"use strict";
var express = require("express");
var app = express();
var bodyParser = require('body-parser');
var request = require('request');
app.use(bodyParser.json());
app.get('/', function(req, res){
res.send('hello');
});
app.get('/webhook', function (req, res) {
if (req.query['hub.verify_token'] === 'my_voice_is_my_password_verify_me') {
res.send(req.query['hub.challenge'])
}
res.send('Error, wrong token')
})
app.post('/webhook', function (req, res) {
let messaging_events = req.body.entry[0].messaging;
for (let i = 0; i < messaging_events.length; i++) {
let event = req.body.entry[0].messaging[i]
let sender = event.sender.id
if (event.message && event.message.text) {
let text = event.message.text
sendTextMessage(sender, "Text received, echo: " + text.substring(0, 200))
}
}
res.sendStatus(200)
})
function sendTextMessage(sender, text) {
let messageData = { text:text }
request({
url: 'https://graph.facebook.com/v2.6/me/messages',
qs: {access_token: process.env.PAGE_ACCESS_TOKEN},
method: 'POST',
json: {
recipient: {id:sender},
message: messageData,
}
}, function(error, response, body) {
if (error) {
console.log('Error sending messages: ', error)
} else if (response.body.error) {
console.log('Error: ', response.body.error)
}
})
}
app.listen(process.env.PORT || 8080);
这可能是Messenger客户端中的一个错误。他们在Android应用程序中遇到很多问题。检查this bug和this bug。
我建议您使用具有下限的rate limiter - 例如每秒最多1个请求 - 来解决问题。这也将防止Messenger未来可能出现的错误。或者您可以等待他们解决客户端中的问题,但请记住,使用过时版本的用户会给您的机器人带来麻烦。
另外,请考虑您可以在邮件事件中收到送达回执。考虑在代码中插入下面的代码段以忽略这些事件。
...
for (let i = 0; i < messaging_events.length; i++) {
let event = req.body.entry[0].messaging[i]
if (event.hasOwnProperty('delivery')) {
continue;
}
...
}
...