我正在尝试设置一个Facebook messenger机器人并继续遇到同样的两个错误。
Webhooks失败了:
禁用Webhooks:
我正在使用NodeJS,Express和服务器创建聊天机器人。我在heroku服务器上运行我的webhook。我已经通过Facebook验证并保存了它。
之后,我运行了这段代码:
curl -ik -X POST "https://graph.facebook.com/v2.6/me/subscribed_apps?access_token=<token>"
这回复了一条成功消息,所以我开始添加代码来回复传入的消息,但我似乎无法将其连接起来。
这是我的代码:
var express = require('express');
var bodyParser = require('body-parser');
var app = express();
var port = process.env.PORT || 3000;
// body parser middleware
app.use(bodyParser.urlencoded({ extended: true }));
app.get('/', function (req, res) {
if (req.query['hub.verify_token'] === '<myToken>') {
res.send(req.query['hub.challenge']);
}
res.send('Error, wrong validation token');
})
app.post('/', function (req, res) {
messaging_events = req.body.entry[0].messaging;
for (i = 0; i < messaging_events.length; i++) {
event = req.body.entry[0].messaging[i];
sender = event.sender.id;
if (event.message && event.message.text) {
text = event.message.text;
sendTextMessage(sender, "Text received, echo: "+ text.substring(0, 200));
}
}
res.sendStatus(200);
});
// error handler
app.use(function (err, req, res, next) {
console.error(err.stack);
res.status(400).send(err.message);
});
app.listen(port, function () {
console.log('Listening on port ' + port);
});
var token = <myToken>;
function sendTextMessage(sender, text) {
messageData = {
text:text
}
request({
url: 'https://graph.facebook.com/v2.6/me/messages',
qs: {access_token:token},
method: 'POST',
json: {
recipient: {id:sender},
message: messageData,
}
}, function(error, response, body) {
if (error) {
console.log('Error sending message: ', error);
} else if (response.body.error) {
console.log('Error: ', response.body.error);
}
});
}
此时我应该可以开始与我的机器人聊天并让它以回声回复,但没有任何事情发生。
感谢任何帮助。谢谢!
答案 0 :(得分:2)
您没有收听正确的端点。
您的app.post('/'
应为
app.post('/webhook', function(req, res) {
var messagingEvents = req.body.entry[0].messaging;
messagingEvents.forEach(function(event) {
var sender = event.sender.id;