Facebook Messenger机器人错误位置0的JSON中的意外令牌'

时间:2018-08-08 19:44:10

标签: node.js facebook facebook-messenger-bot

我正在尝试使用NodeJS和Express创建一个Facebook Messenger机器人。

我正在关注facebook guide,并且在尝试运行此命令时

curl -H "Content-Type: application/json" -X POST "localhost:4000/" -d '{"object": "page", "entry": [{"messaging": [{"message": "TEST_MESSAGE"}]}]}'

我遇到了这个错误SyntaxError: Unexpected token ' in JSON at position 0

这是我的代码:

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

    var app = express();
    var port = process.env.PORT || 4000;

    app.use(bodyParser.json());
    app.use(bodyParser.urlencoded({ extended: true }));

    app.get('/', function(req, res) {
        if (req.query['hub.verify_token'] === '22222') {
            res.send(req.query['hub.challenge']);
            console.log("GET")
            res.sendStatus(200)
        }

        console.log("Error: wrong token")
    })

    app.post('/', function(req, res) {
        messaging_events = req.body.entry[0].messaging;
        console.log("post")
        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 = "<token>";

    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);
            }
        });
    }

我忽略了此错误并启动了漫游器。我通过ngrok连接了Webhooks。我敢肯定,在Facebook上我没事了。但是我没有从Facebook发送消息信息到我的Webhook。]

编辑:'{"object": "page", "entry": [{"messaging": [{"message": "TEST_MESSAGE"}]}]}'这是错误行

2 个答案:

答案 0 :(得分:1)

尝试:

curl -H "Content-Type: application/json" -X POST "localhost:4000/" -d "{""object"": ""page"", ""entry"": [{""messaging"": [{""message"": ""TEST_MESSAGE""}]}]}"

答案 1 :(得分:0)

尝试一下:

curl -H "Content-Type: application/json" -X POST "localhost:4000/webhook" -d "{\"object\": \"page\", \"entry\": [{\"messaging\": [{\"message\":\"TEST_MESSAGE\"}]}]}"

使用\“,因为json解析器需要双引号(”“)进行json解析,我们在这里传递
单引号('')就是解析器无法解析我们传递的json的原因

"{\"object\": \"page\", \"entry\": [{\"messaging\": [{\"message\":\"TEST_MESSAGE\"}]}]}"

检查此内容是否有效。

谢谢