Получение и «Ошибка, неправильный маркер проверки» при попытке создать Chatbot Facebook

голоса
2

Я пытаюсь создать Chatbot Facebook с NodeJS, Express, и сервером Heroku.

Я создал webhook на Heroku и она была проверена и спасена Facebook. Затем я начал добавлять код, который будет отвечать на входящие сообщения, и я не могу показаться, чтобы получить это связано. Он продолжает говорить, что «Ошибка, неправильный маркер проверки», когда я пытаюсь загрузить мой webhook в моем браузере. И когда я пытаюсь отправить бот сообщение я не получаю никакого ответа. Несмотря на то, я уже это проверено и не изменить код.

Вот мой код:

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

Так что я запутался, почему ничего не происходит , и почему я получаю эту ошибку. Я чувствую , что я пропускаю целый шаг. Я выполняю этот учебник, кстати: https://developers.facebook.com/docs/messenger-platform/quickstart

Любая помощь приветствуется. Благодаря!

Edit: Вот мои журналы Heroku

Heroku

Задан 16/04/2016 в 17:13
источник пользователем
На других языках...                            


2 ответов

голоса
0

Вы на самом деле с помощью «запрос», но вы никогда не импортировать его в любом месте. Вот как это исправить:

var request = require("request")

После того, как вы добавили, что в ваш index.js или app.js файл (в основном то, что этот файл), убедитесь, что вы делаете:

npm install request --save

Это должно исправить. К сожалению, Heroku не ошибка, и сказать, что он не знает, что «запрос» есть и вот почему это так трудно понять это в первую очередь!

Ответил 16/04/2016 в 19:06
источник пользователем

голоса
0

  1. Не размещайте ваши полные токенов здесь!
  2. Вы проверили выход на вызов? Так как это просто GET и вы знаете , все значения , которые вы можете попробовать сами: your-app-domain.com/your-callback-url?hub_mode=subscribe&hub_verify_token=the_token_you_set_in_your_app_config&hub_challenge=pingкоторый sould печать «пинг» , если все работает нормально.
  3. Убедитесь, что вы добавляете sendStatus (200) в ответ на хаб вызов тоже.
  4. Вы должны подписаться на страницу в приложении первым. Для этого сделать запрос POST к / вашей-странице-ID / subscribed_apps, который должен вернуть «успех». Вы можете сделать запрос GET к той же конечной точке после двойной проверки приложения подписываются на вашу страницу
  5. Вы не упомянули, какие события вы подписались (должно быть message_deliveries, сообщения, messaging_optins, messaging_postbacks)
  6. Убедитесь, что на вкладку webhooks в вашем приложении панели теперь говорит «полный»
  7. Проверьте еще раз
Ответил 18/04/2016 в 11:34
источник пользователем

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