Facebook error messenger bot "TypeError: Nelze přečíst vlastnost '0' nedefinované".

hlasů
1

Snažím se vytvořit Facebook Chatbot pomocí NodeJS, Express a server Heroku.

Vytvořil jsem webhook na Heroku a měl to ověří a uloží Facebooku. Pak jsem běžel tento kód připojit můj webhook na Facebook.

curl -ik -X POST https://graph.facebook.com/v2.6/me/subscribed_apps?access_token=<token>

Tato vrátil {úspěch: true}.

A tak jsem začal přidávat kód, který bude odpovídat na příchozí zprávy, ale já nedokážu si to přijímat zaslané informace. Kdykoliv jsem poslat zprávu jsem si žádnou odpověď.

Vše je propojeno a běží, ale tato chyba Začínám „TypeError: Nelze přečíst vlastnost‚0‘nedefinované“ je proto, že jsem nedostal obsah zprávy zaslané do mého webhook z Facebooku. Toto je řádek kódu, který je prázdný:

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

Zde je můj úplný kód:

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

Zde jsou mé Heroku Záznamy:

Heroku

Takže jsem zmatená, proč jsem nedostávají se data zprávy, když je moje webhook připojeno k Facebooku a komunikují. Také jsem se ujistil, že jsem všechna pole předplatné nutné zkontrolovat.

Viděl někdo tento problém? Každá pomoc je oceňována. Dík!

Edit: Já sleduji tento návod mimochodem - https://developers.facebook.com/docs/messenger-platform/quickstart

Položena 21/04/2016 v 14:06
zdroj uživatelem
V jiných jazycích...                            


1 odpovědí

hlasů
2

Měl jsem stejný problém. Můžete přidat app.use (bodyParser.json ()) před bodyParser.urlencoded ())?

Odpovězeno 22/04/2016 v 12:43
zdroj uživatelem

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more