Ottenere e "Errore, token di convalida sbagliato" quando si cerca di creare un Chatbot Facebook

voti
2

Sto cercando di creare un chatbot Facebook con NodeJS, Express e un server di Heroku.

Ho creato il mio webhook su Heroku e l'aveva verificato e salvato da facebook. Ho quindi iniziato l'aggiunta di codice che avrebbe rispondere ai messaggi in arrivo e io non riesco a farlo collegato. Si continua a dire Errore, sbagliato token di convalida quando provo a caricare la mia webhook nel mio browser. E quando cerco di inviare il mio bot un messaggio ottengo alcuna risposta. Anche se avevo già è verificato e non modificare il codice.

Ecco il mio codice:

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

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

// body parser middleware
app.use(bodyParser.urlencoded({ extended: true }));

// test route
//app.get('/', function (req, res) { res.status(200).send('Hello world!') });

app.get('/', function (req, res) {
  if (req.query['hub.verify_token'] === '8FKU9XWeSjnZN4ae') {
    res.send(req.query['hub.challenge']);
  }
  res.send('Error, wrong validation token');
})

app.post('/', 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: + text.substring(0, 200));
    }
  }
  res.sendStatus(200);
});

// error handler
app.use(function (err, req, res, next) {
  console.error(err.stack);
  res.status(400).send(err.message);
});

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

Quindi sono confusa sul motivo per cui non succede niente e perché sto ottenendo questo errore. Mi sento come se mi manca un passo intero. Sto seguendo questo tutorial a proposito: https://developers.facebook.com/docs/messenger-platform/quickstart

Ogni aiuto è apprezzato. Grazie!

Edit: Ecco i miei registri di Heroku

registri

È pubblicato 16/04/2016 alle 17:13
fonte dall'utente
In altre lingue...                            


2 risposte

voti
0

In realtà si sta utilizzando "richiesta", ma non si è mai importando da nessuna parte. Ecco come risolvere il problema:

var request = require("request")

Dopo aver aggiunto che ai tuoi index.js o file di app.js (in pratica tutto ciò che questo file è), assicuratevi di fare:

npm install request --save

Questo dovrebbe risolvere il problema. Purtroppo, Heroku non errore fuori e dire che non sa che cosa "richiesta" è ed è per questo che era così difficile da capire questo, in primo luogo!

Risposto il 16/04/2016 a 19:06
fonte dall'utente

voti
0

  1. Non pubblicare i tuoi token di accesso completo qui!
  2. Avete testato l'uscita della sfida? Dal momento che è solo un GET e si sa tutti i valori si può provare voi stessi: your-app-domain.com/your-callback-url?hub_mode=subscribe&hub_verify_token=the_token_you_set_in_your_app_config&hub_challenge=pingche Sould print 'ping' se tutto funziona bene.
  3. Assicurati di aggiungere sendStatus (200) per la risposta sfida hub, anche.
  4. È necessario abbonarsi tua pagina per la prima applicazione. Per fare in modo da fare una richiesta POST / il-tuo-page-id / subscribed_apps che dovrebbe tornare "successo". È possibile effettuare una richiesta GET per lo stesso endpoint in seguito per ricontrollare la vostra applicazione è iscritto alla tua pagina
  5. Lei non ha menzionato quali eventi si è iscritti (deve essere message_deliveries, messaggi, messaging_optins, messaging_postbacks)
  6. Assicurarsi che la scheda webhooks nella vostra applicazione dashboard ora dice "completa"
  7. nuovo test
Risposto il 18/04/2016 a 11:34
fonte dall'utente

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