Unhandled rejection Error: ETELEGRAM: 400 Bad Request: message text is empty

时间:2019-04-23 15:20:18

标签: javascript node.js json telegram node-telegram-bot-api

I'm new to telegram bot and node js, I'm developing a simple bot that calls api urls to get json objects, but I've this error with a command. This is the command's code:

bot.onText(/\/fixtures/, (msg) => {
  const chatId = msg.chat.id;
  var out = "";

  function myFunction(arr) {
      var i;
      for(i = 0; i < arr.length; i++) {
          out += arr[i].name + "--";
      }
  }

  request.onreadystatechange = function() {
      if (this.readyState == 4 && this.status == 200) {
          var myArr = JSON.parse(this.responseText);
          myFunction(myArr);
      }
  };

  request.open("GET", url, true);
  request.send();

  bot.sendMessage(chatId, out);

And this is full error:

Unhandled rejection Error: ETELEGRAM: 400 Bad Request: message text is empty
at request.then.resp (C:\Users\Utente1\Desktop\MyFootballBot\node_modules\node-telegram-bot-api\src\telegram.js:280:15)
at tryCatcher (C:\Users\Utente1\Desktop\MyFootballBot\node_modules\bluebird\js\release\util.js:16:23)
at Promise._settlePromiseFromHandler (C:\Users\Utente1\Desktop\MyFootballBot\node_modules\bluebird\js\release\promise.js:512:31)
at Promise._settlePromise (C:\Users\Utente1\Desktop\MyFootballBot\node_modules\bluebird\js\release\promise.js:569:18)
at Promise._settlePromise0 (C:\Users\Utente1\Desktop\MyFootballBot\node_modules\bluebird\js\release\promise.js:614:10)
at Promise._settlePromises (C:\Users\Utente1\Desktop\MyFootballBot\node_modules\bluebird\js\release\promise.js:694:18)
at _drainQueueStep (C:\Users\Utente1\Desktop\MyFootballBot\node_modules\bluebird\js\release\async.js:138:12)
at _drainQueue (C:\Users\Utente1\Desktop\MyFootballBot\node_modules\bluebird\js\release\async.js:131:9)
at Async._drainQueues (C:\Users\Utente1\Desktop\MyFootballBot\node_modules\bluebird\js\release\async.js:147:5)
at Immediate.Async.drainQueues [as _onImmediate] (C:\Users\Utente1\Desktop\MyFootballBot\node_modules\bluebird\js\release\async.js:17:14)
at runCallback (timers.js:705:18)
at tryOnImmediate (timers.js:676:5)
at processImmediate (timers.js:658:5)

1 个答案:

答案 0 :(得分:1)

您应该在成功ajax请求回复后发送消息。在bot.sendMessage(chatId, out);回调中移动onReadyStateChange

request.onreadystatechange = function() {
    if (this.readyState == 4 && this.status == 200) {
        var myArr = JSON.parse(this.responseText);
        myFunction(myArr);
        bot.sendMessage(chatId, out);
    }
};