利用 Express 托管静态文件

Posted 龙昊雪

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了利用 Express 托管静态文件相关的知识,希望对你有一定的参考价值。

通过 Express 内置的 express.static 可以方便地托管静态文件,例如图片、CSS、javascript 文件等。

将静态资源文件所在的目录作为参数传递给 express.static 中间件就可以提供静态资源文件的访问了。例如,假设在 public 目录放置了图片、CSS 和 JavaScript 文件,你就可以:

app.use(express.static(‘public‘));

现在,public 目录下面的文件就可以访问了。

http://localhost:3000/images/kitten.jpg
http://localhost:3000/css/style.css
http://localhost:3000/js/app.js
http://localhost:3000/images/bg.png
http://localhost:3000/hello.html
所有文件的路径都是相对于存放目录的,因此,存放静态文件的目录名不会出现在 URL 中。

如果你的静态资源存放在多个目录下面,你可以多次调用 express.static 中间件:

app.use(express.static(‘public‘));
app.use(express.static(‘files‘));

访问静态资源文件时,express.static 中间件会根据目录添加的顺序查找所需的文件。

如果你希望所有通过 express.static 访问的文件都存放在一个“虚拟(virtual)”目录(即目录根本不存在)下面,可以通过为静态资源目录指定一个挂载路径的方式来实现,如下所示:

app.use(‘/static‘, express.static(‘public‘));

现在,你就爱可以通过带有 “/static” 前缀的地址来访问 public 目录下面的文件了。

http://localhost:3000/static/images/kitten.jpg
http://localhost:3000/static/css/style.css
http://localhost:3000/static/js/app.js
http://localhost:3000/static/images/bg.png
http://localhost:3000/static/hello.html

 

技术分享图片

以上是关于利用 Express 托管静态文件的主要内容,如果未能解决你的问题,请参考以下文章

利用 Express 托管静态文件

服务器node中间间利用express插件托管静态文件

express(3)—静态资源托管

3 ~ express ~ 静态文件托管

为啥express要指定静态资源托管

node——通过express模拟Apache实现静态资源托管