web-dev-qa-db-ja.com

呼び出されていないエクスプレスグローバルミドルウェア

私が知る限り、ドキュメントとこのテーマに関するすべてのフォーラム投稿で説明されているように、グローバルミドルウェア機能を構成していますが、呼び出されていません。誰かが私が間違っていることを見ていますか?エクスプレス3.2.5。ログ出力には、次のように表示されます。

Express server listening on port 9000
inside route
GET / 200 7ms - 2b

「ミドルウェアの内部」、次に「ルートの内部」が表示されることを期待しています。代わりに、「内部ルート」が表示されます。

コード:

var express = require('express'), http=require('http'), path=require('path');

var app = express();

app.enable('trust proxy');

app.set('port', process.env.PORT || 9000);
app.set('views', __dirname + '/views');
app.set('view engine', 'ejs');
app.set('layout', 'layout');

app.use(require('express-ejs-layouts'));
app.use(express.favicon(__dirname + '/public/images/favicon.ico')); 
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride())
app.use(express.cookieParser('kfiwknks'));
app.use(express.session());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));

if ('development' == app.get('env')) {
  app.use(express.errorHandler());
} else {
  app.use(function(err, req, res, next){
    console.error (error);
    res.send (500, "Internal server error");
  });
}

app.use (function (req, res, next) {
  console.log ("inside middleware");
  next();
});

app.get ("/", function (req, res) {
  console.log ("inside route");
  res.send(200);
});

http.createServer(app).listen(app.get('port'), function() {
  console.log('Express server listening on port ' + app.get('port'));
});

この関連記事:

Express 3エラーミドルウェアが呼び出されていません

エラー処理ミドルウェアに固有です。鉱山はバニラミドルウェアです。

18
Jake

app.routerを使用する前に、ミドルウェアを配置する必要があります。

...
app.use (function (req, res, next) {
  console.log ("inside middleware");
  next();
});
...
app.use(app.router);
29
user568109

Express 4ユーザーの回答を更新 Express 4ドキュメントから 。以下のドキュメントの例を参照してください。 _app.router_は非推奨になり、使用されなくなったことに注意してください。また、順序を明確にするためにダミールートを追加しました。

エラー処理ミドルウェアは、他のapp.use()の後に最後に定義し、呼び出しをルーティングします

例:

_var bodyParser = require('body-parser');

app.use(bodyParser());

app.get('/', function(req, res) {
    res.send('hello world');
})

app.use(function(err, req, res, next) {
  // logic
});
_
12
skeller88