0

bin/www ファイルと app.js ファイルを使用して、express-generator で生成されたアプリがあります。app.js で、次を追加しました。

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

しかし、ミドルウェアをまったく呼び出していません。アプリの残りの部分は正常に動作し、サーバーが実行中でリクエストを受信して​​いることを確認しました。

app.js は次のとおりです。

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var session = require('express-session');
var passport = require('passport');


var routes = require('./routes/index');
var users = require('./routes/users');

//たくさんのルート

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'hbs');

app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use(session({ secret: 'separation anxiety' }));
app.use(passport.initialize());
app.use(passport.session());

app.use('/', routes);
app.use('/users', users);

//たくさんのパス

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

// app.use(auth.isLoggedIn);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  var err = new Error('Not Found');
  err.status = 404;
  next(err);
});

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
  app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
      message: err.message,
      error: err
    });
  });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
  res.status(err.status || 500);
  res.render('error', {
    message: err.message,
    error: {}
  });
});

module.exports = app;
4

1 に答える 1

11

Express ミドルウェアについて知っておくべき重要なことは、それが宣言順に呼び出されるということです。

宣言されたミドルウェアのいずれかが (応答を返すことによって) 要求を処理する場合、その要求は、要求を処理するミドルウェアの後に宣言されたミドルウェアには渡されません。

したがって、他のすべてのミドルウェアが宣言された後に「キャッチオール」ミドルウェアを追加すると、リクエストがミドルウェアに渡されない可能性があります。

これを修正するには、ミドルウェア チェーンの「上位」のどこかでミドルウェアを宣言します。あなたの場合、前に宣言してみてくださいexpress.static

app.use(function(req, res, next){
  console.log("--------new middleware");
  next();
});
app.use(express.static(path.join(__dirname, 'public')));

ミドルウェアチェーンの正しい場所がどこになるかは、ミドルウェアの最終的な目標によって異なります。

または、404 ハンドラーのすぐ上にミドルウェアを追加したため、サーバーから存在しない URL を要求してみてください。これにより、ミドルウェアもトリガーされます。

于 2016-06-24T19:30:56.260 に答える