5

私は以前にこれをやったことがあります... 今回は自分が間違ったことをしていませんが、数時間苦労しており、今では自分が精神的にブロックされていると考えています. 対応するコード:

app.use(express.bodyParser());
app.use(i18next.handle);
app.use(express.methodOverride());
app.use(express.static(__dirname + '/public'));
app.set('views', __dirname + '/views');
app.set('view engine', 'swig');
app.set('view cache', false);
var session_store = new RedisStore({ client : redis_client});
app.use(express.errorHandler({ dumpExceptions : true, showStack : true}));
app.use(express.cookieParser());
app.use(express.session({ store : session_store, secret : SESSION_SECRET, key : "sid" }));
app.use(app.router);

次に、リクエストを処理するときの例を次に示します。

app.get('/session_test', function (req, res, next) {
  console.log(req.session); //undefined
});

redis への接続は正常に機能しています。エラーは表示されません。次に、リクエストからアクセスしようとすると、 req.session が未定義になります。ブラウザは正しい sid を送信しています。

私はリクエスト中に発生する正確なフローの専門家ではありませんが、デバッグ後、セッション ミドルウェアの前にルーターが呼び出されたように見えます。

可能性のあるすべての助けを前もって感謝します。できる限りのコードを提供しますが、何が役立つかわかりません。

ここにもっとコードがあります。サーバー.js

  //Dependency modules
var express = require('express'),
  app = express.createServer(),
  //Application dependency modules
  settings = require('./settings'), //app settings
  routes = require('./routes'), //http routes
  rtroutes = require('./rtroutes'); //real time communication routes (io)

var io = require('socket.io').listen(app);
var appWithSettings = settings.setup(io, app);

routes.settings.setup(appWithSettings);
rtroutes.settings.setup(io, appWithSettings);

routes.settings.setup が呼び出されるまで、ルートは追加されません。settings (グローバル設定) はかなり大きなファイルです。ここですべての構成が完了します。settings.setup メソッドも呼び出されるまで、設定は追加されません。ファイルの一部を次に示します。

//Dependency modules
var express = require('express'),
  redis = require('redis'),
//Important configuration values
var SESSION_SECRET = 'some secret thing which doesnt belong to stackoverflow!',
    insert_other_variables_here = "lalala";

//Computed general objects

var RedisStore = require('connect-redis')(express),
  redis_client = redis.createClient(REDIS_PORT, REDIS_HOST);

exports.setup = function (io, app) {
  app.configure(function () {
    app.use(express.bodyParser());
    app.use(i18next.handle);
    app.use(express.methodOverride());
    app.use(express.static(__dirname + '/public'));
    app.set('views', __dirname + '/views');
    app.set('view engine', 'swig');
    app.set('view cache', false);
    var session_store = new RedisStore({ client : redis_client});
    app.use(express.errorHandler({ dumpExceptions : true, showStack : true}));
    app.use(express.cookieParser());
    console.log("ABOUT TO ADD SESSION STORE MIDDLEWARE");
    app.use(express.session({ store : session_store, secret : SESSION_SECRET, key : "sid" }));
    console.log("AND NOW ADDED THE SESSION STORE MIDDLEWARE");
    app.use(app.router);
  });

  app.configure('development', function () {
     //some things in here, but nothing that affects app. I have commented this
     //for debugging and it changed nothing
  });

  app.configure('production', function () {
    //mostly configuration for io and some caching layers, as well as servers info
    app.use(express.errorHandler());
    app.use(express.logger({ stream : logFile }));
  });
  app.listen(WEB_PORT);
  return {
    app : app,
    //some other stuff that isn't relevant
  }
}

25 のルートを 4 つの異なるファイルに分割しています (いくつかの部分を遅らせていて、必要なすべてが Mongoose で行われていたため、どういうわけか今までセッションは必要ありませんでした)。これがどのように行われているかの例です (偽の名前を使用):

ルート/index.js

export.settings = require("./settings");

ルート/settings.js

exports.setup = function (app_settings) {
  require("./route1")(app_settings);
  require("./route2")(app_settings);
  require("./route3")(app_settings);
};

「route1」ファイル (「routes/route1.js」) を取り除いたものを次に示します。

module.exports = function (app_settings) {
  var app = app_settings.app;
  console.log("ABOUT TO ADD ROUTES")
  app.get("/signin", function (req, res, next) {
    console.log(req.session); //this will be undefined
  });
  app.get("/register", function (req, res, next) {
  });
  app.get('/language', function (req, res, next) {
  });
  app.post('/settings', function (req, res, next) {
  });
  console.log("ADDED ROUTES NOW!")
}
4

2 に答える 2

9

ルートを定義するたびに、ルーターはその時点でのミドルウェアスタックに自動的に挿入されます(その後の意図的な挿入の試みは無視されます)。セッションハンドラーを設定する前に、ルートを定義していませんか?

于 2012-10-03T22:45:19.293 に答える
3

これを更新するのを忘れていました: Ebohlman は私を正しい軌道に乗せました。

i18nextでした。init メソッドの 1 つを呼び出すと、ルートが設定され、app.router がより早くハンドル スタックに強制されていました。残念ながら、コードの一部がアプリ オブジェクトとやり取りしていることに気付きませんでした。私が提供した情報で彼がどのように回答したかよりも、質問にうまく答える方法はなかったので、彼の回答を正しいものとしてマークします.

もっと寝てみようかなvv

于 2012-10-04T10:39:55.603 に答える