如何解决Express服务器为某些路径返回404,但对其他路径则不返回404
因此,基本上backend
文件夹是我从中提供文件的位置,它具有自己的npm软件包。我将视图和静态资产配置如下:
// backend/app.js
...
app.use('/login',controllers.login);
app.use('/images',express.static(__dirname + '/images'));
app.use('/assets',express.static(__dirname + '/assets'));
app.set('views',express.static(__dirname + '/backend/views'));
// backend/controllers/login.js
...
app.get(
'/',function(req,res) {
res.render('login');
}
)
...
// package.json of root folder (i.e. outside /backend)
...
"scripts": {
"start": "cd backend && npm start"
},...
// package.json of /backend folder
...
"scripts": {
"start": "gulp prep && pm2-runtime server.js"
}
...
// gulpfile (in root folder i.e. outside /backend)
...
function movetoServer(cb) {
src(['dist/**'])
.pipe(dest('backend'));
cb();
}
exports.prep = series(buildAssetsAndSavetodistFolder,movetoServer);
...
这在本地运行良好,因此我只需从根文件夹执行npm start
,然后gulp即可构建资产,将其移动到后端文件夹中,然后启动服务器。我可以使用localhost访问它,一切都很好。但是,我尝试在DO液滴上执行相同的操作,并且看到的行为几乎相同,只是backend/assets/
文件夹中的内容始终无法加载并出现404错误。这很奇怪,因为backend/images
文件夹中的内容加载没有问题,但是我已经检查并仔细检查了,backend/assets
中确实存在文件,但它们只是无法加载。需要明确的是,像http://example.com/images/logo.png
这样的请求成功了,但是http://example.com/assets/css/styles.css
给出了404 Not Found
。
有什么想法吗?谢谢!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。