我有一个小型节点服务器,监听Firebase的变化并在特定条件下发送电子邮件。这里的代码:为什么我的firebase回调被多次触发?
var Firebase = require('firebase');
var ref = new Firebase(process.env.FIREBASE_URL);
ref.authWithCustomToken(process.env.FIREBASE_SECRET, function (err) {
if (err) {
console.log(new Date().toString(), 'Firebase Authentication Failed!', err);
EmailService.send('Firebase authentication failed', '[email protected]', err);
} else {
ref.child('applicants').on('child_added', function (snapshot) {
var applicant = snapshot.val();
if (!(applicant.alerts && applicant.alerts.apply)) {
console.log(new Date().toString(), 'New Applicant: ', applicant);
var body = applicant.firstName + ' ' + applicant.lastName + '\n' + applicant.email + '\n' + applicant.phoneNumber;
EmailService
.send('New Applicant', '[email protected]', body)
.then(function() {
ref.child('applicants').child(snapshot.key()).child('alerts').child('apply').set(true);
})
.catch(function (err) { console.log(new Date().toString(), err); });
}
});
}
});
但是,我不断收到重复的电子邮件。最奇怪的部分是,尽管发送了多封电子邮件,但日志仅显示每个申请人的单个“新申请人:...”声明。
任何想法是什么导致这种情况或如何解决它?
谢谢!
嗯,我还以为'如果(!(applicant.alerts && applicant.alerts.apply))'会为每个现有的孩子触发child_added触发一次。看起来好像auth回调被多次调用并导致监听器多次附加,所以我添加了一个名为firstLoad的布尔值,在注册监听器之前检查auth回调,但我仍然得到重复。我可能最终走上队列路线,但我仍然想知道我错过了什么。任何想法,@Kato? – lowe0292 2015-01-27 22:15:03
在问题中没有足够的代码来帮助您找出为什么它被调用的次数不止一次,除了auth方法可能被多次调用的事实以及每次调用每条记录时都会调用该方法负载。我敢肯定,这个游戏的一些变种正在发挥作用,但没有[mcve](http://stackoverflow.com/help/mcve),很难更具体。 – Kato 2015-01-28 14:53:57
对不起@加藤,我打扫了一下代码,试图让它更加mcv。这是[gist](https://gist.github.com/lowe0292/fa3737fdabdff4059629)。谢谢! – lowe0292 2015-01-29 15:45:40