O ile mogę powiedzieć, konfiguruję moją globalną funkcję oprogramowania pośredniego, jak opisano w dokumentach i we wszystkich wpisach na forum na ten temat, ale nie jest to wywoływane. Czy ktoś widzi, co robię źle? ekspresowe 3.2.5. W dzienniku wyjściowym widzę:Ekspresowe globalne oprogramowanie pośredniczące nie jest wywoływane
Express server listening on port 9000
inside route
GET/200 7ms - 2b
Spodziewam się zobaczyć "wewnętrzne oprogramowanie pośrednie", a następnie "wewnątrz trasy". Zamiast tego widzę tylko "wewnątrz trasy".
Kod:
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'));
});
Ta Related Post:
Express 3 error middleware not being called
jest specyficzne dla obsługi błędów middleware. Mine to waniliowe oprogramowanie pośredniczące.
Musisz 'require (" ścieżka ")' –
Dzięki - ścieżka jest wymagana w przykładzie roboczym. Dodałem oświadczenia wymagające ręcznie w poście (i dodałem ścieżkę właśnie teraz do postu). Jeśli ścieżka nie była wymagana, kod po prostu wysadziłby się w powietrze. – Jake
Połóż to oprogramowanie pośrednie przed użyciem app.routera – user568109