Проблемы с ботом Facebook Messenger - PullRequest
0 голосов
/ 11 октября 2018

Я создал чат-мессенджер и попытался развернуть его в первый раз, и после борьбы со всевозможными ошибками я подключил свою страницу, приложение и хуки.

Кажется, что все работает, нет ответа отбот.Это то, что я получаю в журнале ошибок.

Я отправляю "привет" и ничего не возвращаю.Когда я гуглю ответную ошибку, которая появляется, у меня нет решения, которое бы сработало.

enter image description here

    'use strict'

const 
    express=require('express'),
    bodyParser = require('body-parser'),
    app=express().use(bodyParser.json()); //creates http server

    app.listen(process.env.PORT || 5000, () =>console.log('webhook is listening'));

app.post('/webhook', (req, res) => {
    let body=req.body;

    if(body.object === 'page'){
        body.entry.forEach(function(entry){

            //Gets the body of the webhook
            let webhook_event=entry.messaging[0];
            console.log(webhook_event);

            //Gets the sender PSID
            let sender_psid=webhook_event.sender.id;
            console.log('Sender PSID: ' + sender_psid);

        });

        res.status(200).send('EVENT_RECEIVED');
    }else{
        res.sendStatus(404);
    }
    if(webhook_event.message){
        handleMessage(sender_psid, webhook_event.message);
    }else if(webhook_event.postback){
        handlePostback(sender_psid, webhook_event.postback);
    }

});
app.get('/', function (req, res) {
    res.send('This is EngiBot Server');
});
app.get('/webhook', (req, res) => {
    let VERIFY_TOKEN = "testbot_verify_token"

    let mode= req.query['hub.mode'];
    let token=req.query['hub.verify_token'];
    let challange = req.query['hub.challange'];

        if (req.query['hub.verify_token'] === VERIFY_TOKEN) {
        res.send(req.query['hub.challenge']);
    } else {
        res.send('Invalid verify token');
    }

    if(mode && token){
        if(mode==='subscribe' && token === VERIFY_TOKEN){

            console.log('WEBHOOK_VERIFIED');
            res.status(200).send(challange);
        }else{
            res.sendStatus(403);
        }
    }
});

function handleMessages(sender_psid, received_message){
    let response;

    if(received_message.text){
        response = {
            "text": 'You sent the message: "${received_message.text}". Now send an image!'
        }
    }else if(received_message.attachments){
        let attachment_url=received_message.attachments[0].payload.url;
        response = {
            "attachment":{
                "type": "template",
                "payload":{
                    "template_type":"generic",
                    "elements": [{
                        "title": "Is this the right picture?",
                        "subtitle": "Tap a button to answer.",
                        "image_url": attachment_url,
                        "buttons": [
                        {
                            "type": "postback",
                            "title": "Yes!",
                            "payload":"yes",
                        },
                        {
                            "type": "postback",
                            "title": "No!",
                            "payload": "no",
                        }
                        ],
                    }]
                }
            }
        }
    }

    callSendAPI(sender.psid, response);
}

function handlePostback(sender_psid, received_postback){
    let response;

    let payload=received_postback.payload;

    if(payload==='yes'){
        response = {"text": "Thanks!"}
    }else if (payload==="no"){
        response ={"text": "Oops, try sending another image."}
    }
    callSendAPI(sender_psid, response);
}

function callSendAPI(sender_psid, response){
    let request_body={
        "recipient": {
        "id": sender_psid
        },
        "message": response
    }
request({
    "uri":"",
    "qs":{"access_token": PAGE_ACCESS_TOKEN},
    "method": "POST",
"json": request_body
}, (err, res, body)=>{
    if(!err){
        console.log('message sent!')
    }else {
        console.error("Unable to send message:" + err);
    }
});
}

1 Ответ

0 голосов
/ 11 октября 2018

Проблема с POST-роутером.«Webhook_event» объявляется в блоке foreach внутри условного блока, поэтому его область действия является внутренней по отношению к этому блоку.Чтобы решить эту проблему, вы должны переписать свой код в соответствии с областями действия.Это неправильный роутер (я добавил несколько комментариев =

app.post('/webhook', (req, res) => {
    let body=req.body; 
        // webhook_event == null -> true

    if(body.object === 'page'){
        body.entry.forEach(function(entry){

            //Gets the body of the webhook
            let webhook_event=entry.messaging[0]; // webhook_event declared // webhook_event == null -> false
            console.log(webhook_event);

            //Gets the sender PSID
            let sender_psid=webhook_event.sender.id;
            console.log('Sender PSID: ' + sender_psid);

        });

        res.status(200).send('EVENT_RECEIVED');
        if(webhook_event.message){ // ReferenceError cause is not defined
        handleMessage(sender_psid, webhook_event.message);
    }else if(webhook_event.postback){ // ReferenceError cause is not defined
        handlePostback(sender_psid, webhook_event.postback);
    }


    }else{
        res.sendStatus(404);
    }

});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...