解决Nginx配置静态资源文件404 Not Found问题
作者:绛洞花主敏明
在使用Nginx作为静态资源服务器时,如果配置了根目录root导致404错误,而使用前缀URL配置alias则需要正确处理目录路径,使用alias时要确保目录名后加‘/’,并且在需要时使用root和alias配置,本文介绍Nginx配置静态资源文件404 Not Found问题解决方法,感兴趣的朋友一起看看吧
在使用nginx做静态资源服务器时,配置完成后通过浏览器访问一直报404 Not Found错误,本人nginx配置信息如下:
location /images/ { root /mnt/upload/files; }
所有文件存放在/mnt/upload/files
分析:
发现是配置的问题,配置静态路径有两种方式,之前配置的是直接在URL里写根目录,而现在配置是一个有前缀的URL,所以报404 Not Found错误了。
root配置会在配置的目录后跟上URL,组成对应的文件路径,即想访问的地址是:
https://jb51.net/images/a.png
nginx根据配置走的文件路径是
/mnt/upload/files/images/a.png
而我需要的是
/mnt/upload/files/a.png
而Nginx提供了另外一个静态路径配置:alias配置
官方root配置
Sets the root directory for requests. For example, with the following configuration location /i/ { root /data/w3; } The /data/w3/i/top.gif file will be sent in response to the “/i/top.gif” request
官方alias配置
Defines a replacement for the specified location. For example, with the following configuration location /i/ { alias /data/w3/images/; } on request of “/i/top.gif”, the file /data/w3/images/top.gif will be sent.
当访问/i/top.gif时,root是去/data/w3/i/top.gif请求文件,alias是去/data/w3/images/top.gif请求,也就是说
root响应的路径:配置的路径+完整访问路径(完整的location配置路径+静态文件)
alias响应的路径:配置路径+静态文件(去除location中配置的路径)
解决办法:
location /images/ { alias /mnt/upload/files/; }
注意:使用alias时目录名后面一定要加“/”;一般情况下,在location/中配置root,在location /*中配置alias。
到此这篇关于Nginx配置静态资源文件404 Not Found问题解决方法的文章就介绍到这了,更多相关Nginx 静态资源文件404 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:
- nginx 多个location转发任意请求或访问静态资源文件的实现
- Nginx 过滤静态资源文件的访问日志的实现
- 详解Nginx 静态文件服务配置及优化
- 使用nginx缓存服务器上静态文件的设置方法
- Nginx学习之静态文件服务器配置方法
- nginx配置静态文件服务器详解
- 如何在nginx中配置缓存静态文件
- nginx配置https://localhost/index报404
- Nginx出现404 Not Found nginx/1.23.4的完美解决方案
- Nginx上传文件出现“ 413 (499 502 404) Request Entity Too Large错误解决
- Nginx代理接口访问返回404的实现示例