2013-07-17 2 views
9

Насколько я могу судить, я настраиваю свою глобальную функцию промежуточного программного обеспечения, как описано в документах и ​​на каждом форуме, посвященном теме, но это не называется. Кто-нибудь видит, что я делаю неправильно? экспресс 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 error middleware not being called

специфичен для обработки ошибок промежуточного уровня. Шахта - это промежуточное программное обеспечение для ванили.

+0

Вам нужно «потребовать (« путь »)' –

+0

В рабочем примере требуется ссылка «Спасибо». Я добавил необходимые заявления вручную в сообщение (и добавил путь только к сообщению). Если бы путь не требовался, код просто взорвался бы. – Jake

+4

Положите это промежуточное программное обеспечение, прежде чем использовать app.router – user568109

ответ

21

Перед использованием app.router вы должны поместить свое промежуточное программное обеспечение.

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

Большое спасибо - это сделал трюк! Мой взнос заключается в том, что app.router должен быть последним глобальным промежуточным программным обеспечением, добавленным до определения маршрутов. – Jake

+0

Замечательно! Это помогло мне тоже .. – progrrammer

+0

Спасибо! Это помогло мне. –

7

Обновленный ответ для пользователей Экспресса 4 from the Express 4 docs. См. Пример из документов ниже. Обратите внимание, что 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 
}); 

»

 Смежные вопросы

  • Нет связанных вопросов^_^