首页 > 解决方案 > nginx 将所有非 WWW 重定向到 HTTPS WWW

问题描述

Here is what happens:
example.com -> https://example.com
http://example.com -> https://example.com
www.example.com ->  -> https://www.example.com

This is what I want:
example.com -> https://www.example.com
http://example.com -> https://www.example.com
www.example.com ->  -> https://www.example.com

我的 Nginx 配置中缺少什么?我无法从所有类似的问题中找出答案。一些答案说使用“if”语句,但 Nginx 文档明确表示不要这样做,因为它将适用于所有请求。

server {
    listen 80;
    listen 443; # add this line
    server_name example.com;
    return 301 https://www.example.com$request_uri;
}
server {
        listen 80;
        root /var/www/html;
        index index.php;
        server_name example.com www.example.com;

        location / {
                try_files $uri $uri/ =404;
        }

        location ~ \.php$ {
                include snippets/fastcgi-php.conf;
                fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;
        }

        location ~ /\.ht {
                deny all;
        }
}

标签: httpnginxwebhttpsurl-redirection

解决方案


删除第二example.comserver_name块并添加listen 443到第二个块。

希望能帮助到你。

server {
    listen 80;
    listen 443; # add this line
    server_name example.com;
    return 301 https://www.example.com$request_uri;
}

server {
    listen 80;
    listen 443; # add this line too.
    root /var/www/html;
    index index.php;

    # Remove example.com
    server_name www.example.com;

    location / {
            try_files $uri $uri/ =404;
    }

    location ~ \.php$ {
            include snippets/fastcgi-php.conf;
            fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;
    }

    location ~ /\.ht {
            deny all;
    }
}

推荐阅读