1

ここにこのアプリのコミットがあります

基本的な問題は、server.js @ 234 行目に、param オブジェクトのカウンターをインクリメントするメソッドがあることです。これは機能しません。適切なデータモデルについては、models.js を参照してください。

242 行目で、param オブジェクト内のドキュメントの配列であるピボット オブジェクトのカウンターに別のインクリメントがあります。ここでは、同じように設定されたカウンターが機能します。ここで何が間違っているのかわかりません。

編集: github からコードを追加

データモデル

var Pivot = new Schema({
    value       : {type: String, validate: [validateLength, 'length error'] } 
  , destination : {type: String, validate: [validateUrl, 'url error'] } 
  , counter     : {type: Number, default: 0 }
 });



var Param = new Schema({
    title      : {type: String, validate: [validateLength, 'length error'] } 
  , desc       : {type: String, validate: [validateDesc, 'length error'] }
  , defaultUrl : {type: String, validate: [validateUrl, 'url error']  } 
  , counter    : {type: Number, default: 0 }
  , pivots     : [Pivot]
});


mongoose.model('Param', Param);

Route Pre-Param 条件

app.param('title', function(req,res, next){
    Param.findOne({"title":req.param('title')}, function(err, record){
        if (err) return next(err);
        if (!record) return next (new Error('Parameter Not Found') ); 
        req.record = record;
        next();
    });         
}); 


app.param('value', function(req,res, next){
        req.pivot = req.record.findPivot(req);
        if (!req.pivot) return next (new Error('Pivot Not Found') ); 
        next();
}); 

リダイレクト

app.get('/redirect/:title', function(req, res, next){
    req.record.counter++;
    req.record.save();
    res.redirect(req.record.defaultUrl);      
});


app.get('/redirect/:title/:value', function(req, res, next){
    req.pivot.counter++;
    req.record.save();
    res.redirect(req.pivot.destination);
});

いくつかのデバッグ

console.dir(req.record.counter) 親オブジェクトを出力するようで、counter は [Circular] と表示されます。

{ _atomics: {},
  _path: 'counter',
  _parent: 
   { doc: 
      { counter: [Circular],
        pivots: [Object],
        _id: 4dce2a3399107a8a2100000c,
        title: 'varun',
        desc: 'my blog',
        defaultUrl: 'http://varunsrin.posterous.com/' },
     activePaths: 
      { paths: [Object],
        states: [Object],
        stateNames: [Object],
        map: [Function] },
     saveError: null,
     isNew: false,
     pres: { save: [Object] },
     errors: undefined } }

上記のパラメーターのピボット「gmail」で console.dir(req.pivot.counter) を実行すると、戻ります。この場合、カウンターが増加し、正常に表示されます

{ _atomics: {},
  _path: 'counter',
  _parent: 
   { parentArray: 
      [ [Circular],
        _atomics: [],
        validators: [],
        _path: 'pivots',
        _parent: [Object],
        _schema: [Object] ],
     parent: undefined,
     doc: 
      { counter: [Circular],
        _id: 4dce2a6499107a8a21000011,
        value: 'gmail',
        destination: 'http://www.gmail.com/' },
     activePaths: 
      { paths: [Object],
        states: [Object],
        stateNames: [Object] },
     saveError: null,
     isNew: false,
     pres: { save: [Object] },
     errors: undefined } }
4

1 に答える 1

0

これは Mongoose v1.3.5 で再び動作することが確認されました。コードは問題なく、Mongoose にはバグがありました。

Mongoose v.1.3.1 - 1.3.3 のバグであることが判明しました。最近のコミットで修正されましたが、まだメイン ビルドには含まれていません

https://github.com/LearnBoost/mongoose/issues/342

于 2011-05-15T23:48:54.453 に答える