无法将 webhook 连接到 Facebook Messenger 机器人
Trouble connecting webhook to Facebook messenger bot
我正在尝试使用 NodeJS、Express 和 heroku 服务器创建一个 Facebook 聊天机器人。
我在 heroku 上创建了我的 webhook,并通过 Facebook 对其进行了验证和保存。然后我 运行 此代码将我的 webhook 连接到 Facebook。
curl -ik -X POST "https://graph.facebook.com/v2.6/me/subscribed_apps?access_token=<token>"
这返回了{success:true}。
然后我开始添加代码来回复收到的消息,但我似乎无法连接。每当我发送消息时,我都没有收到回复。
这是我的代码:
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('wyrdbot.herokuapp.com', 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);
}
});
}
我一直在尝试调试它并发现 app.post 函数根本不是 运行。我也一直收到错误消息,说我的 webhook 已被禁用。
当我检查我的日志时,我发现打印了很多次:
2016-04-20T14:13:31.487873+00:00 heroku[router]: at=info method=POST path="/" host=wyrdbot.herokuapp.com request_id=fa1e5270-5038-4e67-b7a6-c6852c7c3000 fwd="173.252.90.101" dyno=web.1 connect=0ms service=16ms status=404 bytes=212
我完全不知道要尝试什么。有人知道我错过了什么吗?
如有任何帮助,我们将不胜感激。谢谢!
尝试 app.post('/', 函数 (req, res) {
使用app.use(bodyParser.json());
因为 Facebook 正在请求正文中发送 JSON 数据。
我正在尝试使用 NodeJS、Express 和 heroku 服务器创建一个 Facebook 聊天机器人。
我在 heroku 上创建了我的 webhook,并通过 Facebook 对其进行了验证和保存。然后我 运行 此代码将我的 webhook 连接到 Facebook。
curl -ik -X POST "https://graph.facebook.com/v2.6/me/subscribed_apps?access_token=<token>"
这返回了{success:true}。
然后我开始添加代码来回复收到的消息,但我似乎无法连接。每当我发送消息时,我都没有收到回复。
这是我的代码:
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('wyrdbot.herokuapp.com', 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);
}
});
}
我一直在尝试调试它并发现 app.post 函数根本不是 运行。我也一直收到错误消息,说我的 webhook 已被禁用。
当我检查我的日志时,我发现打印了很多次:
2016-04-20T14:13:31.487873+00:00 heroku[router]: at=info method=POST path="/" host=wyrdbot.herokuapp.com request_id=fa1e5270-5038-4e67-b7a6-c6852c7c3000 fwd="173.252.90.101" dyno=web.1 connect=0ms service=16ms status=404 bytes=212
我完全不知道要尝试什么。有人知道我错过了什么吗?
如有任何帮助,我们将不胜感激。谢谢!
尝试 app.post('/', 函数 (req, res) {
使用app.use(bodyParser.json()); 因为 Facebook 正在请求正文中发送 JSON 数据。