我想像通常那样处理静态文件,express.static(static_path)
但像通常那样处理动态路由
app.get('/my/dynamic/:route', function(req, res){
// serve stuff here
});
其中一位开发人员在此评论中提出了解决方案,但我不清楚他的意思。
我想像通常那样处理静态文件,express.static(static_path)
但像通常那样处理动态路由
app.get('/my/dynamic/:route', function(req, res){
// serve stuff here
});
其中一位开发人员在此评论中提出了解决方案,但我不清楚他的意思。
static
中间件。滚动到中间件页面底部,然后将源代码复制并粘贴到您的路由中。希望从那里开始,您可以使其适应static
中间件的工作方式,以提供静态文件。否则,只需使用fs.readFile
。
Answers:
好的。我在Express的response object的源代码中找到了一个示例。这是该示例的稍作修改的版本。
app.get('/user/:uid/files/*', function(req, res){
var uid = req.params.uid,
path = req.params[0] ? req.params[0] : 'index.html';
res.sendFile(path, {root: './public'});
});
它使用该res.sendFile
方法。
注意:安全性更改sendFile
要求使用此root
选项。
'../dir/' + file
因为express认为这是恶意的用户输入(非常好)。而是使用以下命令来发送相对于某个目录的文件: response.sendfile(file, {root: './dir/'})
res.render(page, pageParameters)
呢?
我使用以下代码来提供不同网址请求的相同静态文件:
server.use(express.static(__dirname + '/client/www'));
server.use('/en', express.static(__dirname + '/client/www'));
server.use('/zh', express.static(__dirname + '/client/www'));
尽管这不是您的情况,但它可能会对到达这里的其他人有所帮助。
/user/:uid
(注意:uid之前的冒号)之类的路由中提供静态文件
您可以使用res.sendfile
或仍然可以使用express.static
:
const path = require('path');
const express = require('express');
const app = express();
// Dynamic path, but only match asset at specific segment.
app.use('/website/:foo/:bar/:asset', (req, res, next) => {
req.url = req.params.asset; // <-- programmatically update url yourself
express.static(__dirname + '/static')(req, res, next);
});
// Or just the asset.
app.use('/website/*', (req, res, next) => {
req.url = path.basename(req.originalUrl);
express.static(__dirname + '/static')(req, res, next);
});
这应该工作:
app.use('/my/dynamic/:route', express.static('/static'));
app.get('/my/dynamic/:route', function(req, res){
// serve stuff here
});
文档指出动态路由app.use()
有效。参见https://expressjs.com/en/guide/routing.html
app.use(express.static('./public'));
中间件,为什么我们还需要app.use('/viewVob/:id', express.static('./public'));
为所有参数化路由也有另一个中间件?