Facebook messenger bot错误“TypeError:无法读取未定义的属性'0'。”

时间:2016-04-21 14:06:00

标签: node.js facebook facebook-graph-api facebook-chatbot

我正在尝试使用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}。

然后我开始添加可以回复传入消息的代码,但我似乎无法接收发送的信息。每当我发送消息时,我都没有回复。

所有内容都已连接并正在运行但是我收到此错误“TypeError:无法读取未定义的属性'0'是因为我没有收到从facebook发送到我的webhook的消息信息。这是空行的代码行:

messaging_events = req.body.entry[0].messaging;

这是我的完整代码:

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('/', 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);
    }
  });
}

这是我的Heroku日志:

Heroku Logs

所以我很困惑,为什么当我的webhook连接到Facebook并且他们正在进行通信时,我没有收到消息数据。我还确保我必须检查所有订阅字段。

有人看到了这个问题吗?任何帮助表示赞赏。谢谢!

编辑:我正在按照本指南进行操作 - https://developers.facebook.com/docs/messenger-platform/quickstart

1 个答案:

答案 0 :(得分:2)

我遇到了同样的问题。你能在bodyParser.urlencoded()之前添加app.use(bodyParser.json())吗?