0

ノードで遊んでいて、リクエストにCookieを設定しようとしましたが、未定義の例外が発生します。これが私のサンプルアプリケーションです

var express = require('express');

var app = module.exports = express();

process.env.NODE_ENV = 'production';

app.configure('production', function(){
    app.set('views', __dirname + '/views');
    app.set('view engine', 'jade');
    app.use(express.cookieParser());
    app.use(express.bodyParser());
    app.use(express.methodOverride());
    app.use(app.router);
    app.use(express.static(__dirname + '/public'));
});

app.get("/", function(req, res){
    res.cookie('cart', 'test', {maxAge: 900000, httpOnly: true});

    res.send("OK");
});

app.get('/users/:id', function(req, res) {
    var s = req.params.id;

    res.send('testcookie: ' + req.cookies.cart);
});    


app.listen(3000);
console.log('Listening on port 3000');

チャールズで、Cookieを取得して返していることを確認できます。

ここに画像の説明を入力してください

しかし、(:idは明らかにいくつかの数値です)に移動するたびに/users:id、cookiesオブジェクトが未定義であるというメッセージが表示されます。

TypeError: Cannot read property 'cart' of undefined
    at c:\Projects\app\app.js:29:42
    at callbacks (c:\Projects\app\node_modules\express\lib\router\index.js:161:37)
    at param (c:\Projects\app\node_modules\express\lib\router\index.js:135:11)
    at param (c:\Projects\app\node_modules\express\lib\router\index.js:132:11)
    at pass (c:\Projects\app\node_modules\express\lib\router\index.js:142:5)
    at Router._dispatch (c:\Projects\app\node_modules\express\lib\router\index.js:170:5)
    at Object.router (c:\Projects\app\node_modules\express\lib\router\index.js:33:10)
    at next (c:\Projects\app\node_modules\express\node_modules\connect\lib\proto.js:199:15)
    at Object.expressInit [as handle] (c:\Projects\app\node_modules\express\lib\middleware.js:31:5)
    at next (c:\Projects\app\node_modules\express\node_modules\connect\lib\proto.js:199:15)

上記を他のミドルウェアの上に置くことに関する他のすべてのSOの質問を読みました。cookieParserすべてのアカウントから、この例は機能するはずですが、何が欠けているのか途方に暮れています。

4

1 に答える 1

1

わかりました、それは私がどのように設定したかに関係していることがわかりましたapp.configureproduction上記で明示的に設定されていると思っていても、app configureの内部がENVの初期化関数を呼び出していなかったため、configureコールバック関数が呼び出されませんでした。

これを修正するために、をに変更するprocess.env.NODE_ENVapp.settings.env、すべてが機能し始めました。

ここでその情報を見つけました:エクスプレスアプリが実行されている現在のNODE_ENVを見つける方法は?

于 2013-02-20T21:03:49.430 に答える