ฉันได้เปลี่ยนไฟล์ conf เพื่อที่ว่าเมื่อผู้ใช้พิมพ์ในโดเมนโดยไม่มี www มันจะเปลี่ยนเส้นทางไปยังโดเมนด้วย www:

server_name example.com; ส่งคืน 301 $scheme://www.example.com$request_uri; ฉันยังต้องการ https ของฉันภายใต้ /user

ฉันได้รับข้อผิดพลาดของ too may redirects ฉันผิดพลาดตรงไหน

ฉันมี:

server {
listen 80 default_server;
listen [::]:80 default_server ipv6only=on;

root /var/www/example.com/site;
index index.html index.htm;

# Make site accessible from http://localhost/
server_name example.com;
return 301 $scheme://www.example.com$request_uri;

location / {
        # First attempt to serve request as file, then
        # as directory, then fall back to displaying a 404.
        try_files $uri $uri/ =404;
        # Uncomment to enable naxsi on this location
        # include /etc/nginx/naxsi.rules
}
location /user {
        rewrite ^ https://$http_host$request_uri? permanent;
}
}

สำหรับพอร์ต 443:

server {
listen 443;
server_name example.com;
return 301 $scheme://www.example.com$request_uri;

root /var/www/example.com/site;
index index.html index.htm;

ssl on;
ssl_certificate //path here
ssl_certificate_key //path here

location / {
        rewrite ^ http://$http_host$request_uri? permanent;
}
location /user {
}
}
answer

วิธีที่ดีที่สุดที่จะทำคือจะมีการแยกต่างหากserverบล็อคและexample.com www.example.comรายการสำหรับexample.comควรมีเฉพาะ :

server {
    listen       80;
    server_name  example.com;
    return       301 http://www.example.com$request_uri;
}

รายการสำหรับwww.example.comจะมีทุกอย่างอื่น (และแน่นอนว่าไม่มีการเปลี่ยนเส้นทาง)

คุณจะมีรายการเซิร์ฟเวอร์สองรายการแยกกันสำหรับ https (พอร์ต 443)

ฉันจะทำสิ่งนี้: (ยังไม่ทดลอง)

server {
listen       80;
server_name  example.com;
return       301 http://www.example.com$request_uri;
}
server {
       listen       80;
       server_name  www.example.com;
       root /var/www/example.com/site;
       index index.html index.htm;

location / {
       rewrite ^/index.php;
          }
}
server {
   listen 443;
   server_name www.example.com;
   root /var/www/example.com/site;
   index index.html index.htm;

   ssl on;
   ssl_certificate //path here
   ssl_certificate_key //path here


  location /user {
                  rewrite ^ https://$http_host$request_uri? permanent;
                 }
 }