server
{
server_name www.vanging.com;
root /web/sites/vanging.com/;
include modules/general.conf;
include modules/ssl.conf;
ssl_certificate certs/vanging.com/www/cert.pem;
ssl_certificate_key certs/vanging.com/www/cert.key;
error_log /web/sites/vanging.com/logs/www/error.log debug;
access_log /web/sites/vanging.com/logs/www/access.log;
location = /
{
root /web/sites/vanging.com/www;
}
}
---------------------------
in modules/general.conf:
listen 80;
index index.html;
add_header Access-Control-Allow-Origin * ;
---------------------------
in modles/ssl.conf:
listen 443 http2;
ssl on;
# Perfect_Forward_Security,Diffie-Hellman
ssl_dhparam dhparam.pem;
ssl_session_cache shared:SSL:1m;
ssl_session_timeout 5m;
ssl_ciphers ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA:ECDHE-RSA-AES256-SHA:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA256:AES128-GCM-SHA256:AES256-GCM-SHA384:DES-CBC3-SHA;
ssl_prefer_server_ciphers on;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_stapling on;
ssl_stapling_verify on;
# http-->https
if ($server_port = 80)
{
return 301 https://$server_name$request_uri;
}
if ($scheme = http)
{
return 301 https://$server_name$request_uri;
}
error_page 497 https://$server_name$request_uri;
add_header Strict-Transport-Security "max-age=15768000; includeSubDomains; preload";
在上面的配置中,我想将我网站的主页放在文档根目录的 www 目录中,但是规则 location =/对带有 url https://www.vanging.com 的传入请求没有任何影响。 .
有人可以帮忙吗?
谢谢!
最佳答案
最后我从其他地方找到了这背后的原因:Index 指令通过内部重定向工作。请求确实匹配规则 location =/但它将被内部重定向到/index.html,因此出现 404。
要解决此问题,请使用 try_files 指令 indtead,它不会导致内部重定向。
很高兴得到你的帮助,希望能帮助到同样被这个问题迷惑的人。
谢谢大家!
关于linux - Nginx : the rule( location =/) in server context do not work,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44115001/