Php Nginx位置块导致请求返回404状态
我正在尝试为存储在Php Nginx位置块导致请求返回404状态,php,laravel,nginx,devops,Php,Laravel,Nginx,Devops,我正在尝试为存储在/storage/文件夹中的正在获取的文件的任何响应自动添加标题 每当我使用此位置块时: 位置/存储/{ 添加标题“访问控制允许源”*; } 我收到404回复: HTTP/1.1 404 Not Found Server: nginx/1.19.4 Date: Tue, 17 Nov 2020 20:44:52 GMT Content-Type: image/jpeg Content-Length: 28300 Connection: keep-alive ETag: &qu
/storage/
文件夹中的正在获取的文件的任何响应自动添加标题
每当我使用此位置块时:
位置/存储/{
添加标题“访问控制允许源”*;
}
我收到404回复:
HTTP/1.1 404 Not Found
Server: nginx/1.19.4
Date: Tue, 17 Nov 2020 20:44:52 GMT
Content-Type: image/jpeg
Content-Length: 28300
Connection: keep-alive
ETag: "5fb37909-6e8c"
一旦我注释掉位置块条件:
#位置/存储/{
添加标题“访问控制允许源”*;
#}
它正确地添加了标题
HTTP/1.1 200 OK
Server: nginx/1.19.4
Date: Tue, 17 Nov 2020 20:46:12 GMT
Content-Type: image/jpeg
Content-Length: 28300
Last-Modified: Tue, 17 Nov 2020 07:17:29 GMT
Connection: keep-alive
ETag: "5fb37909-6e8c"
Access-Control-Allow-Origin: *
Accept-Ranges: bytes
为了排除任何权限问题,我将试图获取的文件权限(图像)设置为777
如果有人想浏览完整的nginx.conf,请访问:
server {
listen 127.0.0.1:80 default_server;
root /;
charset utf-8;
client_max_body_size 128M;
location /storage/ {
add_header Access-Control-Allow-Origin *;
}
location /41c270e4-5535-4daa-b23e-c269744c2f45/ {
internal;
alias /;
try_files $uri $uri/;
}
location / {
rewrite ^ "/Users/chrisbreuer/.composer/vendor/laravel/valet/server.php" last;
}
location = /favicon.ico { access_log off; log_not_found off; }
location = /robots.txt { access_log off; log_not_found off; }
access_log off;
error_log "/Users/chrisbreuer/.config/valet/Log/nginx-error.log";
error_page 404 "/Users/chrisbreuer/.composer/vendor/laravel/valet/server.php";
location ~ [^/]\.php(/|$) {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass "unix:/Users/chrisbreuer/.config/valet/valet.sock";
fastcgi_index "/Users/chrisbreuer/.composer/vendor/laravel/valet/server.php";
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME "/Users/chrisbreuer/.composer/vendor/laravel/valet/server.php";
fastcgi_param PATH_INFO $fastcgi_path_info;
}
location ~ /\.ht {
deny all;
}
}
任何帮助都将不胜感激,因为我不确定它为什么会抛出404,因为它可以在浏览器中查看,并且其他标题(内容类型
,内容长度
)都被正确添加,表明图像已“找到”
非常感谢
编辑1
我不确定这是否有区别,但“存储”文件夹是一个符号链接
编辑2
nginx错误:
2020/11/17 12:45:50 [error] 64990#0: *1 open() "/storage/media/1/1/turtle.jpg" failed (2: No such file or directory), client: 127.0.0.1, server: , request: "HEAD /storage/media/1/1/turtle.jpg HTTP/1.1", host: "my-api.test"
当我尝试访问浏览器
my api.test/storage/media/1/1/turtle.jpg中的URL时,它将返回图像而不是404。服务器的根目录设置为/
因此,当您指定/storage/location时,它会在/storage/media/1/1/turtle.jpg
中查找一个文件,该文件打印在日志中,但由于文件不在其中而失败
删除此位置块时,它将使用具有“重写”命令的location/
因此,如果您修改存储位置并在其中包含适当的重写指令,这应该是可行的。请注意,这需要进行一些调整才能达到正确的效果-请参阅此处的文档:
最后,静态内容的最佳实践是根本不使用重写,而是在磁盘上为其确定适当的位置,并修改root
指令以匹配该位置并避免重写。这将提高性能和可读性