0

在 express 中调用下面的路由时,实际上执行了 6 次。console.log 打印了 6 次,我的 mongoose 逻辑执行了 6 次(在数据库中节省了 6 次)。

然后我从 cloud9ide “无法代理请求”返回一个 http 500。我真的很困惑,我的代码中没有循环,这怎么会发生?console.log("在 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");
                            }
                    }); 
                }
            }); 
        }
    }
}
4

1 回答 1

1

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

于 2012-03-23T15:17:11.327 回答