facebook - 尝试设置 Facebook Messenger 机器人时出现 "Webhooks failing"和 "webhooks disabled"错误

标签 facebook facebook-graph-api heroku bots chatbot

我正在尝试设置 Facebook Messenger 机器人,但不断遇到同样的两个错误。

Webhook 失败:

Webhooks failing

Webhook 已禁用:

Webhooks disabled

我正在使用 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);
    }
  });
}

此时我应该能够开始与我的机器人聊天并让它回复回声,但什么也没有发生。

感谢任何帮助。谢谢!

最佳答案

您没有在正确的端点上监听。 你的 app.post('/' 应该是

    app.post('/webhook', function(req, res) {
    var messagingEvents = req.body.entry[0].messaging;

    messagingEvents.forEach(function(event) {
    var sender = event.sender.id;

关于facebook - 尝试设置 Facebook Messenger 机器人时出现 "Webhooks failing"和 "webhooks disabled"错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36696226/

相关文章:

ruby-on-rails - Heroku 服务器无法与 Devise 配合使用

Android:Android SDK 与 Facebook for Android 应用程序之间的冲突

android - 具有隐式授权的 OAuth 应用程序中的客户端模拟

facebook - 如何使用 Facebook Social Graph API 给某人点赞?

java - 如何作为应用程序发布到页面?

ruby-on-rails - Rails 和 Heroku 上的定期后台作业

ruby-on-rails - 如何在 heroku 上使用本地 gem?

用于聚合我的社交媒体流的 PHP 库

javascript - ReactJS - 如何更改 React 组件的样式和类?

javascript - 通过 Chrome 扩展在 Facebook 上分享