Http Route多次调用

时间:2012-03-11 02:42:55

标签: node.js express mongoose cloud9-ide everyauth

当在express中调用以下路由时,它实际执行了6次。 console.log打印6次,我的mongoose逻辑执行6次(在数据库中保存6次)。

然后我从cloud9ide“无法代理请求”返回http 500。我真的很困惑,我的代码中没有循环,这怎么可能发生? console.log(“in else(2)”);打印6次。

编辑:我已经尝试了mongooseLogic代码,其中各个部分被注释掉了,问题仍然存在。看起来这不是一个猫鼬问题。

第二次编辑:我更改了get的帖子并硬编码了将要发送的正文,并且路由只执行了一次。

第三次编辑:我也使用everyauth与facebook oauth进行会话/身份验证。

app.post("/result/:userId/:elementId", function(req, res) {
  var receivedJSON = req.body;    

  console.log("In route");

  //Making sure the receive request is valid
  if(typeof(receivedJSON.type) !== undefined) {
    mongooseLogic.saveResults(req.params.elementId, receivedJSON, req.params.userId, function(message) {
      if(message === "Success") {
        res.json({ success: true,  message: 'Result saved.'});    
      }
      else {
        res.json({ success: false,  message: 'Error in saving results. Trace: ' + message});
      }
    });
  }
  else {
    res.json({ success: false,  message: 'Failed, Invalid object sent to server'});   
  }
});

mongooseLogic文件上的代码:

var saveResults = function(elementRefId, receivedResult, userId, callback){

    if(elementRefId.toString().length !== 24 ){
       callback("Invalid objectId for elementId");
    }
    else{
            Result.findOne({ "id" : userId, "serieResult.id": elementRefId }, function(err, result){
                if(err){
                    callback("No Document found: " + err);
                }
                else if( result === null){
                    console.log("in null");
                    var tempResult =  {
                        id           : elementRefId, 
                        unit         : receivedResult.unit, 
                        value        : receivedResult.value 
                    }
                    Result.update({ "id" : userId}, { $push: {"serieResult": tempResult}}, {upsert: true}, function(err){
                        if(err){
                            callback("Error in saving result (Distance): " + err);
                        }
                        else{
                            callback("Success");
                        }
                    });
                }
                else{            
                    Result.update({ "id" : userId, "serieResult.id": elementRefId },
                        { $set:{
                            "serieResult.$.unit"        : receivedResult.unit,
                            "serieResult.$.value"       : receivedResult.value,
                        },{upsert: true}, function(err){
                            if(err){
                                callback("Cant update doc: " + err);
                            }
                            else{
                                console.log("in else (2)");
                                 callback("Success");
                            }
                    }); 
                }
            }); 
        }
    }
}

1 个答案:

答案 0 :(得分:1)

这是受干扰的Cloud9代理的问题。由于这个问题,问题得到解决,并已得到解决。