Как решить проблему перенаправления не-www на www Nginx?

Это моя конфигурация веб-сервера NGinx

    server {
        if ($host ~ ^[^.]+\.betafox\.net$) {
            return 301 https://$host$request_uri;
        } # managed by Certbot
    
    
        if ($host = www.betafox.net) {
            return 301 https://$host$request_uri;
        } # managed by Certbot
    
    
        if ($host = betafox.net) {
            return 301 https://$host$request_uri; 
        } # managed by Certbot
    
        listen 80;
        listen [::]:80;
    
        #server_name _;
        root /var/www/html;
    
    server_name betafox.net *.betafox.net;
        #return 301 https://$host$request_uri;
        index index.php index.html index.htm;
        location / {
            # try_files $uri $uri/ =404;
            try_files $uri $uri/ /index.php?q=$uri&$args;
            proxy_pass  https://betafox.net/;
            proxy_redirect  https://betafox.net/ $host;
            proxy_set_header Accept-Encoding "";
            proxy_ssl_server_name on;
        }
        location ~ \.php$ {
            include snippets/fastcgi-php.conf;
            #fastcgi_pass 127.0.0.1:9000;
            #fastcgi_pass unix:/run/php/php8.0-fpm.sock;
            fastcgi_pass unix:/etc/alternatives/php-fpm.sock;
     }
    
    
    }
    
    server {
    
    listen 443 ssl default_server;
            listen [::]:443 ssl default_server;
    
            root /var/www/html;
            index index.php index.html index.htm;
    
          # server_name _;
            server_name betafox.net *.betafox.net;
            # Maximum file upload size is 4MB - change accordingly if needed
            client_max_body_size 512M;
            client_body_buffer_size 128k;
            include snippets/letsencrypt-nginx-certs.conf;
            include snippets/letsencrypt-nginx-route.conf;
    
            location / {
                    # try_files $uri $uri/ =404;
                    try_files $uri $uri/ /index.php?q=$uri&$args;
            }
    error_page 404 /404.html;
    
            error_page 500 502 503 504 /50x.html;
            location = /50x.html {
                    root /usr/share/nginx/html;
            }
    
            location ~ \.php$ {
                    include snippets/fastcgi-php.conf;
                    #fastcgi_pass 127.0.0.1:9000;
                    #fastcgi_pass unix:/var/run/php8.0-fpm.sock;
                    fastcgi_pass unix:/etc/alternatives/php-fpm.sock;
            }
        ssl_certificate /etc/letsencrypt/live/betafox.net-0001/fullchain.pem; # managed by Certbot
        ssl_certificate_key /etc/letsencrypt/live/betafox.net-0001/privkey.pem; # managed by Certbot
    
    }

Большая ее часть была автоматически изменена Certbot, когда я устанавливал SSL-сертификаты как для своего полного доменного имени, так и для поддоменов. Проблема, с которой я столкнулся, связана с перенаправлением URL. Исходный URL-адрес www.betafox.net , когда пользователь вводит betafox.net, он перенаправляется наhttps://betafoxnet.www.betafox.net/и появляется сообщение :Сайт, который вы искали, не существует.

Я только хочу, чтобы все пользователи, вводящие betafox.net, перенаправлялись на www.betafox.net . Я считаю, что Nginx может это сделать. Как я могу добиться такого?

0
задан 11 November 2021 в 17:42
1 ответ

К сожалению, Certbot создает перенаправления nginx, используя ifс переменной $host, что проблематично.

Лучше всего иметь перенаправление в отдельном разделе serverследующим образом.

# Redirect all requests to betafox.net URLs to corresponding www.betafox.net URLs
server {
    listen 80;
    listen 443 ssl http2;

    ssl_certificate /etc/letsencrypt/live/betafox.net-0001/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/betafox.net-0001/privkey.pem; # managed by Certbot

    server_name betafox.net;

    return 301 https://www.betafox.net$request_uri;
}

# Redirect all other subdomain HTTP requests to HTTPS.
server {
    listen 80;

    server_name *.betafox.net;

    return 301 https://$http_host$request_uri;:
}

# Removed the server block for port 80, it looked meaningless

server {
    # Removed the default_server, default_server should not be the actual website
    listen 443 ssl;
    listen [::]:443 ssl;

    root /var/www/html;
    index index.php index.html index.htm;

    server_name betafox.net *.betafox.net;
    # Maximum file upload size is 4MB - change accordingly if needed
    client_max_body_size 512M;
    client_body_buffer_size 128k;
    include snippets/letsencrypt-nginx-certs.conf;
    include snippets/letsencrypt-nginx-route.conf;

    location / {
        try_files $uri $uri/ /index.php?q=$uri&$args;
    }
    error_page 404 /404.html;

    error_page 500 502 503 504 /50x.html;
    location = /50x.html {
        root /usr/share/nginx/html;
    }

    location ~ \.php$ {
        include snippets/fastcgi-php.conf;
        fastcgi_pass unix:/etc/alternatives/php-fpm.sock;
    }
    ssl_certificate /etc/letsencrypt/live/betafox.net-0001/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/betafox.net-0001/privkey.pem; # managed by Certbot
}
1
ответ дан 14 November 2021 в 13:59

Теги

Похожие вопросы