通常,您不希望向外界公开服务器内部结构的任何内部路径。您可以做的是/scripts
在服务器中建立一条静态路由,从它们碰巧驻留的任何目录中获取文件。因此,如果文件位于"./node_modules/bootstrap/dist/"
。然后,页面中的脚本标签如下所示:
<script src="/scripts/bootstrap.min.js"></script>
如果您对nodejs使用express,那么静态路由就这么简单:
app.use('/scripts', express.static(__dirname + '/node_modules/bootstrap/dist/'));
然后,来自的所有浏览器请求/scripts/xxx.js
都将自动从您的dist
目录中获取__dirname + /node_modules/bootstrap/dist/xxx.js
。
注意:较新版本的NPM会将更多内容放在顶层,而不是嵌套得太深,因此,如果您使用较新版本的NPM,则路径名将不同于OP的问题和当前答案中指示的名称。但是,概念仍然相同。您可以找到文件在服务器驱动器上的物理位置,并app.use()
使用它们express.static()
来建立这些文件的伪路径,这样就不会向客户端公开实际的服务器文件系统组织。
如果您不想创建这样的静态路由,那么最好将公共脚本复制到Web服务器确实要处理的路径/scripts
或您要使用的任何顶级名称。通常,您可以将此复制作为构建/部署过程的一部分。
如果只想在目录中公开一个特定文件,而不是在该目录中找到所有文件,则可以为每个文件手动创建单独的路由,而不必使用express.static()
诸如:
<script src="/bootstrap.min.js"></script>
以及为此创建路线的代码
app.get('/bootstrap.min.js', function(req, res) {
res.sendFile(__dirname + '/node_modules/bootstrap/dist/bootstrap.min.js');
});
或者,如果您仍想使用来描绘脚本的路由/scripts
,则可以执行以下操作:
<script src="/scripts/bootstrap.min.js"></script>
以及为此创建路线的代码
app.get('/scripts/bootstrap.min.js', function(req, res) {
res.sendFile(__dirname + '/node_modules/bootstrap/dist/bootstrap.min.js');
});