【发布时间】:2016-07-29 21:03:01
【问题描述】:
Node.js 新手。
我正在使用 VS2015 Express 3 模板。如何将我的路由写入:
- 在“/”处有一个页面
- 有一条以主页“/”响应的全部路由
- 不干扰 JS 和 CSS 文件
即,我尝试了以下操作,但公共目录中的 JS 和 CSS 文件响应 404 不渲染或执行。我认为静态文件代码会处理它,但事实并非如此。它一直有效,直到我用“*”添加块。
var express = require('express');
var routes = require('./routes');
var http = require('http');
var path = require('path');
var app = express();
// all environments
app.set('port', process.env.PORT || 3000);
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.json());
app.use(express.urlencoded());
app.use(express.methodOverride());
app.use(app.router);
app.use(require('stylus').middleware(path.join(__dirname, 'public')));
app.use(express.static(path.join(__dirname, 'public')));
// development only
if ('development' == app.get('env')) {
app.use(express.errorHandler());
}
app.get('/', routes.index);
app.get('*', function (req, res) {
res.send('/', 404);
});
http.createServer(app).listen(app.get('port'), function () {
console.log('Express server listening on port ' + app.get('port'));
});
【问题讨论】:
-
如果你真的只是想添加一个 404 处理程序,那么请看这里:expressjs.com/en/starter/faq.html#how-do-i-handle-404-responses
-
表达
static中间件必须定义在所有其他中间件之前:app.use(express.static(path.join(__dirname, 'public')));,放在app.set('view engine', 'jade');之后 -
这是一篇关于在 node.js 中正确处理 404 和 500 错误的好文章:hacksparrow.com/express-js-custom-error-pages-404-and-500.html。
app.get('*',...)不是你应该做的。