2012-05-08 6 views
13

ここPassport.jsがミドルウェアエラーを表示するのはなぜですか?

https://github.com/jaredhanson/passport/issues/14

app.use(passport.initialize()); 
app.use(passport.session()); 
app.use(app.router); 
app.use(express.static(__dirname + '/public')); 

を説明するように、私は回避策をしようとしている細かい

app.use(app.router); 
app.use(express.static(__dirname + '/public')); 
app.use(passport.initialize()); 
app.use(passport.session()); 

ワークスは、あなたはまだパスポート後app.use(app.router)に必要

DEBUG: Error: passport.initialize() middleware not in use 
    at IncomingMessage.<anonymous> (/.../node_modules/passport/lib/passport/http/request.js:30:30) 
    at Context.<anonymous> (/.../node_modules/passport/lib/passport/middleware/authenticate.js:92:11) 
    at Context.<anonymous> (/.../core/node_modules/passport/lib/passport/context/http/actions.js:21:25) 
    at Strategy.success (native) 

答えて

26

を与えます。そうしないと、あなたのルートはPassportコードの前に実行されます。そのため、エラーが表示されます。これはうまくいくはずです:

app.use(express.static(__dirname + '/public')); 
app.use(passport.initialize()); 
app.use(passport.session()); 
app.use(app.router); 
0

私は同じ問題があったかもしれません。私のアプリの設定はこのように見えました。これによりエラーが発生しました。

app.configure(function() { 
    .... 
app.use(app.router);  
app.use(passport.initialize()); 
app.use(passport.session()); 
app.use(express.static(path.join(__dirname, 'public'))); 

}); 

私はそれが機能するためには以下のように並べ替える必要がありました。

app.configure(function() { 
    .... 
app.use(passport.initialize()); 
app.use(passport.session()); 
app.use(app.router);  
app.use(express.static(path.join(__dirname, 'public'))); 

});