我試圖用NodeJS,Express和Heroku服務器創建Facebook chatbot。試圖創建Facebook Chatbot時獲取和「錯誤,錯誤的驗證令牌」
我在heroku上創建了我的webhook,並通過facebook驗證並保存。然後我開始添加能夠回覆傳入消息的代碼,但似乎無法連接。當我嘗試在我的瀏覽器中加載我的webhook時,它總是說「錯誤,錯誤的驗證令牌」。當我嘗試向我的機器人發送消息時,我無法回覆。儘管我已經驗證過它,並沒有更改代碼。
這裏是我的代碼:
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 }));
// test route
//app.get('/', function (req, res) { res.status(200).send('Hello world!') });
app.get('/', function (req, res) {
if (req.query['hub.verify_token'] === '8FKU9XWeSjnZN4ae') {
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);
}
});
}
所以我很困惑,爲什麼什麼也沒有發生,爲什麼我收到錯誤。我覺得我錯過了一整步。順便說一句,我正在關注本教程:https://developers.facebook.com/docs/messenger-platform/quickstart
任何幫助表示讚賞。謝謝!
編輯:這是我的Heroku的日誌
我有同樣的問題。基本上我得到一個500錯誤。而已! – helicopter
我希望有更好的文檔。我明白,因爲它是如此新 –