【发布时间】:2017-02-17 00:16:03
【问题描述】:
我已将 node.js 服务器上传到 heroku。它的目的是向我的用户发送通知。它正在监听 firebase 数据库并发送通知。问题是,一个小时左右的工作后,它停止发送通知,当我在 heroku 上打开应用程序时,它又开始工作了。这真的很奇怪。有任何想法吗?我的代码和这个类似
var firebase = require('firebase');
var request = require('request');
var express = require('express');
var app = express();
app.set('port', (process.env.PORT || 5000));
var API_KEY = "..."; // Your Firebase Cloud Server API key
firebase.initializeApp({
serviceAccount: ".json",
databaseURL: "https://.firebaseio.com/"
});
ref = firebase.database().ref();
function listenForNotificationRequests() {
var requests = ref.child('notificationRequests');
ref.on('child_added', function(requestSnapshot) {
var request = requestSnapshot.val();
sendNotificationToUser(
request.username,
request.message,
function() {
request.ref().remove();
}
);
}, function(error) {
console.error(error);
});
};
function sendNotificationToUser(username, message, onSuccess) {
request({
url: 'https://fcm.googleapis.com/fcm/send',
method: 'POST',
headers: {
'Content-Type' :' application/json',
'Authorization': 'key='+API_KEY
},
body: JSON.stringify({
notification: {
title: message
},
to : '/topics/user_'+username
})
}, function(error, response, body) {
if (error) { console.error(error); }
else if (response.statusCode >= 400) {
console.error('HTTP Error: '+response.statusCode+' - '+response.statusMessage);
}
else {
onSuccess();
}
});
}
app.listen(app.get('port'), function() {
listenForNotificationRequests();
});
【问题讨论】:
标签: node.js heroku firebase firebase-cloud-messaging