3

NodeJS、Express、および Heroku サーバーを使用して Facebook チャットボットを作成しようとしています。

Heroku で Webhook を作成し、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

どんな助けでも大歓迎です。ありがとう!

編集:ここに私のherokuログがあります

Heroku ログ

4

2 に答える 2