3

我正在尝试使用 NodeJS、Express 和 Heroku 服务器创建一个 Facebook 聊天机器人。

我在 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日志

Heroku 日志

4

2 回答 2

1
  1. 不要在此处发布您的完整访问令牌!
  2. 你测试过挑战的输出吗?因为它只是一个 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”。
  3. 确保您也将 sendStatus(200) 添加到集线器质询响应中。
  4. 您需要先将您的页面订阅到该应用程序。为此,向 /your-page-id/subscribed_apps 发出 POST 请求,该请求应返回“成功”。之后您可以向同一端点发出 GET 请求,以仔细检查您的应用是否订阅了您的页面
  5. 您没有提及您订阅了哪些事件(需要是 message_deliveries、messages、messaging_optins、messaging_postbacks)
  6. 确保您的应用仪表板中的 webhook 选项卡现在显示“完成”
  7. 再次测试
于 2016-04-18T11:34:52.507 回答
0

您实际上正在使用“请求”,但您从未在任何地方导入它。以下是解决方法:

var request = require("request")

一旦你将它添加到你的 index.js 或 app.js 文件(基本上不管这个文件是什么),确保你这样做:

npm install request --save

这应该解决它。不幸的是,Heroku 并没有出错并说它不知道“请求”是什么,这就是为什么一开始就很难弄清楚这一点!

于 2016-04-16T19:06:29.147 回答