快速版本是最新的。
这是app.js文件,另一个app.js文件使用它:
"use strict";
var express = require('express'), engine = require('ejs-locals');
var path = require('path'), map = require('../../app').map;
var register = require('./routes/register').register;
var profile = require('./routes/profile').profile;
var login = require('./routes/login').login;
var app = module.exports = express();
app.configure(function() {
app.engine('ejs', engine);
app.set('views', __dirname + '/views');
app.set('view engine', 'ejs');
app.use('/assets', express.static(path.join(__dirname, 'assets')));
});
app.configure('development', function() {
app.use(express.errorHandler());
});
app.map = map;
app.map(app, {
'/seller': {
'/password': {
get: login.forgot, // Looks in the correct place /assets/css/... etc.
'/forgot': {
get: login.forgot // Looks in wrong place /seller/assets/... etc.
},
'/reset': {
get: login.reset
}
}
}
});
当请求get
http://localhost:3000/seller/password
时,express会在正确的位置查找静态文件,即/assets/css/。但是当请求get
http://localhost:3000/seller/password/forgot
时,express会在错误的位置查找静态文件,即/seller/assets/css,它们甚至都不存在。这是map函数。它取自快车route-map example。
function route_map(app, a, route) {
route = route || '';
for (var key in a) {
switch (typeof a[key]) {
case 'object': // { '/path': { ... }}
app.map(app, a[key], route + key);
break;
case 'function': // get: function(){ ... }
app[key](route, a[key]);
break;
}
}
}
最佳答案
请求错误文件的应该是浏览器,而不是express,express是服务器。因此,您的客户端html可能是错误的,可能它试图转到../../assets/css
当您的url是/seller/password/
时是正确的,因为它有两个级别,您的css请求有两个向上的目录,但是,当您的url是/seller/password/forgot
时,它试图向上两个级别,现在是/seller
所以它在之后附加/assets/css
。