Это моя конфигурация веб-сервера 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 может это сделать. Как я могу добиться такого?
К сожалению, 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
}