Facebook Messenger API:无法获取POST请求

ozg*_*zer 3 node.js facebook-messenger

我按照本页中的步骤 https://developers.facebook.com/docs/messenger-platform/quickstart

我的nodejs代码

app.post('/webhook/', 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: ");
        }
    }
    res.sendStatus(200);
});
Run Code Online (Sandbox Code Playgroud)

我得到这样的错误

TypeError: Cannot read property 'entry' of undefined
    at /home/user/public_html/app/testbot/webhook.js:31:30
    at Layer.handle [as handle_request] (/home/user/public_html/app/testbot/node_modules/express/lib/router/layer.js:95:5)
    at next (/home/user/public_html/app/testbot/node_modules/express/lib/router/route.js:131:13)
    at Route.dispatch (/home/user/public_html/app/testbot/node_modules/express/lib/router/route.js:112:3)
    at Layer.handle [as handle_request] (/home/user/public_html/app/testbot/node_modules/express/lib/router/layer.js:95:5)
    at /home/user/public_html/app/testbot/node_modules/express/lib/router/index.js:277:22
    at Function.process_params (/home/user/public_html/app/testbot/node_modules/express/lib/router/index.js:330:12)
    at next (/home/user/public_html/app/testbot/node_modules/express/lib/router/index.js:271:10)
    at serveStatic (/home/user/public_html/app/testbot/node_modules/express/node_modules/serve-static/index.js:74:16)
    at Layer.handle [as handle_request] (/home/user/public_html/app/testbot/node_modules/express/lib/router/layer.js:95:5)
Run Code Online (Sandbox Code Playgroud)

我无法获得来自Facebook的POST请求.我怎么解决这个问题?

Man*_*ler 12

我遇到了同样的问题.你需要使用body-parser lib:

var express = require('express');
var bodyParser = require('body-parser');

var app = express();
var jsonParser = bodyParser.json();
Run Code Online (Sandbox Code Playgroud)

然后将它传递给post hook

app.post('/webhook/', jsonParser, function(req, res) {
Run Code Online (Sandbox Code Playgroud)

  • 好的,我做到了.这是一个非常愚蠢的问题:)`var request = require("request");` (3认同)
  • 嘿,谢谢你的回答.这很棒,工作完美.现在我得到`console.log(text);`消息但是facebook的`sendTextMessage()`函数还有另一个问题.我无法向Facebook聊天发送任何数据.新错误是"ReferenceError:请求未定义".您是否在编码时注意到此错误,并且您有解决方案吗? (2认同)