2016-04-20 159 views
1

我想創建一個使用NodeJS,Express和一個Herkuku服務器的Facebook chatbot。麻煩連接webhook到Facebook messenger bot

我在heroku上創建了我的webhook,並通過Facebook進行了驗證和保存。然後我運行這段代碼將我的webhook連接到Facebook。

curl -ik -X POST "https://graph.facebook.com/v2.6/me/subscribed_apps?access_token=<token>" 

返回{success:true}。

因此,我開始添加回復傳入消息的代碼,但似乎無法連接。每當我發送消息,我都沒有回覆。

這裏是我的代碼:

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

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

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

app.get('/', function (req, res) { 
    if (req.query['hub.verify_token'] === '8FKU9XWeSjnZN4ae') { 
    res.send(req.query['hub.challenge']); 
    console.log("app.get ran") 
    res.sendStatus(200) 
    } 

    console.log("Error: wrong validation token") 
}) 

app.post('wyrdbot.herokuapp.com', function (req, res) { 
    messaging_events = req.body.entry[0].messaging; 
    console.log("app.post ran") 
    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); 
}); 

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

我一直在試圖調試,並實現了app.post功能不包括在所有運行。我也一直在收到錯誤,說我的webhook已被禁用。

當我檢查我的日誌我覺得這是打印出一堆時間:

2016-04-20T14:13:31.487873+00:00 heroku[router]: at=info method=POST path="/" host=wyrdbot.herokuapp.com request_id=fa1e5270-5038-4e67-b7a6-c6852c7c3000 fwd="173.252.90.101" dyno=web.1 connect=0ms service=16ms status=404 bytes=212 

我完全是出於什麼嘗試的想法。任何人都知道我錯過了什麼?

任何幫助,將不勝感激。謝謝!

回答

1

使用app.use(bodyParser.json()); 如Facebook是請求發送體JSON數據

0

嘗試app.post( '/',函數(REQ,RES){

+0

這有幫助,'app.post'函數現在正在運行,但它沒有得到消息數據。我知道這是因爲我得到一個_TypeError:無法讀取undefined_ error的屬性'0'。保持消息數據爲空。 –