noa*_*hai 12 node.js express firebase-realtime-database firebase-admin
我有一个来自firebase的错误:
FIREBASE警告:用户回调引发了异常.RangeError:超出最大调用堆栈大小
我没有发现我的错误.
我在这里很迷茫,请帮忙.
我的代码看起来像这样:
app.post('/updateCoords', (req, res)=>{
var usrID = req.body.id;
var usrCoords = {
lat: req.body.lat,
long: req.body.long
}
console.log('userID : '+usrID+' lat : '+usrCoords.lat+' long : '+usrCoords.long);
var ref = database.ref('users');
try{
ref.orderByChild('username').equalTo(usrID).on("value", (snapshot)=> {
if(!snapshot.val()){
// Error
return res.json({msg: 'username is not in D.B', success: false});
}
// Success
admin.database().ref('users/' + usrID + '/currentLocation').update({
lat: usrCoords.lat,
long: usrCoords.long
});
return res.json({msg: 'user coords changed', success: true});
});
}catch(ex){
console.log('ex /updateCoords = '+ex);
}
});
Run Code Online (Sandbox Code Playgroud)
Fra*_*len 15
您正在更新您正在阅读的同一节点.这会导致on("value"再次触发回调.然后依次写入一个新值,再次触发回调.并且一直持续到运行时用尽调用堆栈空间.
最简单的解决方案是使用once()而不是on():
var ref = database.ref('users');
try{
ref.orderByChild('username').equalTo(usrID).once("value", (snapshot)=> {
if(!snapshot.val()){
checker = true;
}
if(snapshot.val()){
admin.database().ref('users/' + usrID + '/currentLocation').update({
lat: usrCoords.lat,
long: usrCoords.long
});
return res.json({msg: 'user coords changed', success: true});
// checker = false;
}
// res.json({msg: 'username is not in D.B', success: false});
});
}catch(ex){
console.log('ex /updateCoords = '+ex);
}
Run Code Online (Sandbox Code Playgroud)