使用api.ai和heroku(node.js)在Facebook messenger聊天机器人中的OAuth异常

时间:2017-09-23 05:00:30

标签: node.js facebook heroku dialogflow facebook-chatbot

我已经分享了我的代码以及下面弹出的错误。基本上,我按照教程http://www.girliemac.com/blog/2017/01/06/facebook-apiai-bot-nodejs/和另一个教程。我的聊天机器人适用于smalltalk但不适用于天气api的东西。我想让聊天机器人给我关于不同城市天气的答案。我完全按照教程。

  Error:  { message: '(#100) No matching user found',
  type: 'OAuthException',
   code: 100,
  error_subcode: 2018001,
   fbtrace_id: 'DeubaTWU6Gg' }
 Error:  { message: '(#100) No matching user found',
   type: 'OAuthException',
   code: 100,
   error_subcode: 2018001,
   fbtrace_id: 'FSiMes3IwHv' }

//来自index.js的代码仅用于天气api的东西

 app.post('/ai', (req, res) => {
  //console.log('*** Webhook for api.ai query ***');
  //console.log(req.body.result);

  if (req.body.result.action === 'weather') {
 //  console.log('*** weather ***');
    let city = req.body.result.parameters['geo-city'];
    let restUrl = 'http://api.openweathermap.org/data/2.5/weather?APPID='+process.env.WEATHER_API_KEY+'&q='+city;

    request.get(restUrl, (err, response, body) => {
      if (!err && response.statusCode == 200) {
        let json = JSON.parse(body);
       // console.log(json);
        let tempF = ~~(json.main.temp * 9/5 - 459.67);
        let tempC = ~~(json.main.temp - 273.15);
        let msg = 'The current condition in ' + json.name + ' is ' + json.weather[0].description + ' and the temperature is ' + tempF + ' ℉ (' +tempC+ ' ℃).'
        return res.json({
          speech: msg,
          displayText: msg,
          source: 'weather'
        });
      } else {
        let errorMessage = 'I failed to look up the city name.';
        return res.status(400).json({
          status: {
            code: 400,
            errorType: errorMessage
          }
        });
      }
    })
  }

});

如何修复此错误?

1 个答案:

答案 0 :(得分:1)

错误是因为您使用recipient.id中的邮件发送的页面范围ID无效。假设您已经从教程中正确设置了sendMessage()函数,很可能问题是您使用与机器人聊天的Facebook帐户没有正确的角色。

如果机器人不公开(即尚未提交和批准),您用于向机器人发送消息的Facebook帐户必须在您的应用设置中获得管理员,开发人员或测试人员角色。

相关问题