我在使用 nginx 配置从 HTTPS www 重定向到 HTTPS 非 www 时遇到了一些问题。我按照以下说明操作(使用 nginx 删除“www”并重定向到“https”)。
目前正在进行以下工作:
- http://www.redemfit.com->https://redemfit.com
- http://redemfit.com->https://redemfit.com
- https://redemfit.com
但事实并非如此:
我最终得到了“欢迎使用 nginx!”页面。我也没有其他 nginx 配置文件/sites-enabled
。有什么想法可以解释为什么会这样吗?
我的配置文件如下。
upstream redemfit {
server unix:/srv/redemfit/run/gunicorn.sock fail_timeout=0;
}
server {
listen 80;
server_name www.redemfit.com redemfit.com;
rewrite ^ https://redemfit.com$request_uri? permanent;
}
server {
listen 443;
ssl on;
ssl_certificate /etc/ssl/private/redemfit-bundle.crt;
ssl_certificate_key /etc/ssl/private/redemfit.key;
ssl_protocols SSLv3 TLSv1;
ssl_ciphers ALL:!aNULL:!ADH:!eNULL:!LOW:!EXP:RC4+RSA:+HIGH:+MEDIUM;
server_name www.redemfit.com
rewrite ^ https://redemfit.com$request_uri? permanent;
}
server {
listen 443;
ssl on;
ssl_certificate /etc/ssl/private/redemfit-bundle.crt;
ssl_certificate_key /etc/ssl/private/redemfit.key;
ssl_protocols SSLv3 TLSv1;
ssl_ciphers ALL:!aNULL:!ADH:!eNULL:!LOW:!EXP:RC4+RSA:+HIGH:+MEDIUM;
server_name redemfit.com;
client_max_body_size 4G;
access_log /srv/redemfit/logs/nginx-access.log;
error_log /srv/redemfit/logs/nginx-error.log;
gzip on;
gzip_disable "msie6";
gzip_vary on;
gzip_proxied any;
gzip_comp_level 6;
gzip_buffers 16 8k;
gzip_http_version 1.1;
gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;
location /static {
auth_basic off;
root /srv/redemfit/static_collected;
}
location / {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
if (!-f $request_filename) {
proxy_pass http://redemfit;
break;
}
}
}
答案1
尝试移除 HTTPSserver {}
阻止www.redemfit.com完整地将下面的代码添加到主 HTTPS 块中:
if ($host = 'www.redemfit.com' ) {
rewrite ^/(.*)$ https://redemfit.com/$1 permanent;
}
我希望你在写这篇文章时犯了一个错别字:
server {
listen 443;
ssl on;
ssl_certificate /etc/ssl/private/redemfit-bundle.crt;
ssl_certificate_key /etc/ssl/private/redemfit.key;
ssl_protocols SSLv3 TLSv1;
ssl_ciphers ALL:!aNULL:!ADH:!eNULL:!LOW:!EXP:RC4+RSA:+HIGH:+MEDIUM;
server_name www.redemfit.com # <- Missing semicolon
rewrite ^ https://redemfit.com$request_uri? permanent;
}