Я пытаюсь создать Chatbot Facebook с помощью NodeJS, Express, и сервер Heroku.
Я создал webhook на Heroku и она была проверена и сохранена на Facebook. Я побежал этот код, чтобы подключить webhook в Facebook.
curl -ik -X POST https://graph.facebook.com/v2.6/me/subscribed_apps?access_token=<token>
Возвращаемый {успех: истинно}.
Затем я начал добавлять код, который будет отвечать на входящие сообщения, но я не могу показаться, чтобы получить его, чтобы получить отправленную информацию. Всякий раз, когда я отправляю сообщение, я не получаю никакого ответа.
Все взаимосвязано и работает, но эта ошибка я получаю «Ошибка типа: Не удается прочитать свойство„0“неопределенных», потому что я не получаю информацию сообщения, отправленного на мой webhook от Facebook. Это строка кода, которая является пустым:
messaging_events = req.body.entry[0].messaging;
Вот мой полный код:
var express = require('express');
var bodyParser = require('body-parser');
var request = require(request)
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'] === '8FKU9XWeSjnZN4ae') {
res.send(req.query['hub.challenge']);
console.log(app.get ran)
res.sendStatus(200)
}
console.log(Error: wrong validation token)
})
app.post('/', function (req, res) {
messaging_events = req.body.entry[0].messaging;
console.log(app.post ran)
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);
});
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);
}
});
}
Вот мои журналы Heroku:
Так что я запутался, почему я не получаю данные сообщения, когда мой webhook подключен к Facebook, и они общаются. Я также уверен, что я имел все подписные поля необходимо проверяются.
Кто-нибудь видел эту проблему? Любая помощь приветствуется. Благодаря!
Изменить: Я следую за это руководство, кстати - https://developers.facebook.com/docs/messenger-platform/quickstart














