0

次のルートをエクスプレスで呼び出すと、実際には6回実行されます。console.logは6回出力され、私のマングースロジックは6回実行されます(データベースに6回保存されます)。

次に、cloud9ideからhttp500「リクエストをプロキシできませんでした」が返されます。私は本当に混乱しています、コードにループがありません、これはどのように起こりますか?console.log( "in else(2)"); 6回印刷されます。

編集:私はさまざまな部分がコメントアウトされたmongooseLogicコードを試しましたが、問題はまだありました。これはマングースの問題ではないようです。

2番目の編集:getの投稿を変更し、送信される本文をハードコードしました。ルートは1回だけ実行されました。

3番目の編集:Facebookのoauthとのセッション/認証にもeveryauthを使用しています。

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 に答える