尝试创建 Facebook Chatbot 时获取和 "Error, wrong validation token"
Getting and "Error, wrong validation token" when trying to create a Facebook Chatbot
我正在尝试使用 NodeJS、Express 和 Heroku 服务器创建一个 Facebook 聊天机器人。
我在 heroku 上创建了我的 webhook,并通过 facebook 对其进行了验证和保存。然后我开始添加代码来回复收到的消息,但我似乎无法连接它。当我尝试在我的浏览器中加载我的 webhook 时,它一直说 "Error, wrong validation 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 }));
// 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 日志
您实际上正在使用 "request",但您从未将其导入任何地方。修复方法如下:
var request = require("request")
将其添加到 index.js 或 app.js 文件(基本上无论该文件是什么)后,确保您执行以下操作:
npm install request --save
这应该可以解决问题。不幸的是,Heroku 不会出错并说它不知道 "request" 是什么,这就是为什么一开始就很难弄清楚!
- 不要在此处post您的完全访问令牌!
- 你测试过挑战的输出了吗?因为它只是一个 GET 并且您知道所有值,所以您可以自己尝试:
your-app-domain.com/your-callback-url?hub_mode=subscribe&hub_verify_token=the_token_you_set_in_your_app_config&hub_challenge=ping
如果一切正常,它将打印 'ping'。
- 确保您也将 sendStatus(200) 添加到集线器质询响应中。
- 您需要先为您的页面订阅该应用程序。为此,向 /your-page-id/subscribed_apps 发出 POST 请求,应该 return "success"。之后您可以向同一端点发出 GET 请求,以仔细检查您的应用程序是否订阅了您的页面
- 您没有提及您订阅了哪些活动(需要是 message_deliveries、消息、messaging_optins、messaging_postbacks)
- 确保您的应用面板中的 webhooks 选项卡现在显示 "complete"
- 再次测试
我正在尝试使用 NodeJS、Express 和 Heroku 服务器创建一个 Facebook 聊天机器人。
我在 heroku 上创建了我的 webhook,并通过 facebook 对其进行了验证和保存。然后我开始添加代码来回复收到的消息,但我似乎无法连接它。当我尝试在我的浏览器中加载我的 webhook 时,它一直说 "Error, wrong validation 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 }));
// 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 日志
您实际上正在使用 "request",但您从未将其导入任何地方。修复方法如下:
var request = require("request")
将其添加到 index.js 或 app.js 文件(基本上无论该文件是什么)后,确保您执行以下操作:
npm install request --save
这应该可以解决问题。不幸的是,Heroku 不会出错并说它不知道 "request" 是什么,这就是为什么一开始就很难弄清楚!
- 不要在此处post您的完全访问令牌!
- 你测试过挑战的输出了吗?因为它只是一个 GET 并且您知道所有值,所以您可以自己尝试:
your-app-domain.com/your-callback-url?hub_mode=subscribe&hub_verify_token=the_token_you_set_in_your_app_config&hub_challenge=ping
如果一切正常,它将打印 'ping'。 - 确保您也将 sendStatus(200) 添加到集线器质询响应中。
- 您需要先为您的页面订阅该应用程序。为此,向 /your-page-id/subscribed_apps 发出 POST 请求,应该 return "success"。之后您可以向同一端点发出 GET 请求,以仔细检查您的应用程序是否订阅了您的页面
- 您没有提及您订阅了哪些活动(需要是 message_deliveries、消息、messaging_optins、messaging_postbacks)
- 确保您的应用面板中的 webhooks 选项卡现在显示 "complete"
- 再次测试