Jak*_*ake 17 middleware node.js express
据我所知,我正在配置我的全局中间件功能,如文档和关于该主题的每个论坛帖子中所述,但它没有被调用.有谁看到我做错了什么?表达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'));
});
这篇相关帖子:
特定于错误处理中间件.我的是一个香草中间件.
use*_*109 30
您应该在使用之前放置中间件app.router.
...
app.use (function (req, res, next) {
  console.log ("inside middleware");
  next();
});
...
app.use(app.router);
ske*_*r88 12
从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
});
"
| 归档时间: | 
 | 
| 查看次数: | 11182 次 | 
| 最近记录: |