Nginx: Redirecionando http para https (erro: muitos redirecionamentos)

2

Executando o Nginx e tentando redirecionar:

www to non-www

http to https

Sei que existem tópicos semelhantes, mas nenhum com o mesmo cenário.

Instalei o Webmin / Virtualmin e o Fast-CGI. Eu tenho muitas contas / sites neste servidor. Para mysite, esse é o bloco do servidor:

server {
    listen my_server_IP;
    server_name example.com www.example.com;
    return 301 https://example.com$request_uri;
    root /home/example/public_html;
    index index.html index.htm index.php;
    access_log /var/log/virtualmin/example.com_access_log;
    error_log /var/log/virtualmin/example.com_error_log;
    fastcgi_param GATEWAY_INTERFACE CGI/1.1;
    fastcgi_param SERVER_SOFTWARE nginx;
    fastcgi_param QUERY_STRING $query_string;
    fastcgi_param REQUEST_METHOD $request_method;
    fastcgi_param CONTENT_TYPE $content_type;
    fastcgi_param CONTENT_LENGTH $content_length;
    fastcgi_param SCRIPT_FILENAME /home/example/public_html$fastcgi_script_name;
    fastcgi_param SCRIPT_NAME $fastcgi_script_name;
    fastcgi_param REQUEST_URI $request_uri;
    fastcgi_param DOCUMENT_URI $document_uri;
    fastcgi_param DOCUMENT_ROOT /home/example/public_html;
    fastcgi_param SERVER_PROTOCOL $server_protocol;
    fastcgi_param REMOTE_ADDR $remote_addr;
    fastcgi_param REMOTE_PORT $remote_port;
    fastcgi_param SERVER_ADDR $server_addr;
    fastcgi_param SERVER_PORT $server_port;
    fastcgi_param SERVER_NAME $server_name;
    fastcgi_param HTTPS $https;
    location ~ \.php$ {
        try_files $uri =404;
        fastcgi_pass unix:/var/php-nginx/148180748420424.sock/socket;
    }
    # htaccess
    location / {
        try_files $uri $uri/ /index.php?$args;
    }
    #
    listen my_server_IP:443 ssl;
    ssl_certificate /home/example/ssl.cert;
    ssl_certificate_key /home/example/ssl.key;
}

Agora, a configuração como parece agora, não é da minha conta, além do bit #htaccess (convertido do .htaccess do Apache para ativar "links bonitos" no Wordpress) e a linha "retornar 301".

O certificado SSL é de LetsEncrypt, se isso faz diferença.

Eu salvei e reiniciei o Nginx.

Ao solicitar o site no Chrome, ele me diz "ERR_TOO_MANY_REDIRECTS"

O que estou fazendo de errado? Preciso adicionar ou remover alguma coisa?

    
por Trace DeCoy 20.12.2016 / 15:15

1 resposta

3

Esta é uma versão simplificada da sua configuração atual (menos todos os bits que atualmente não farão nada de conteúdo) com algumas notas adicionadas para que você possa ver o que está acontecendo. As duas últimas linhas apenas continuam enviando as coisas de volta ao começo. Daí para muitos erros de redirecionamentos.

server {
    listen my_server_IP; #listen on IP x.x.x.x
    listen my_server_IP:443 ssl; #listen on IP x.x.x.x on 443
    server_name example.com www.example.com; #Of the requests on IP x.x.x.x look for those with with one of these headers. send to line below       
    return 301 https://example.com$request_uri; #Send everything to the line above
    } 

Isto é o que você precisa, você pode usar uma declaração if , mas não permite que desta vez, apenas para que você possa ver claramente o que está acontecendo. É mais linhas, mas vai funcionar.

server {
    listen my_server_IP;
    server_name example.com www.example.com; #Listen for non-https requests 
    return 301 https://example.com$request_uri; #Send to the correct https address
    }
server {
    listen my_server_IP:443 ssl;
    server_name www.example.com; #Listen for https (www) requests
    return 301 https://example.com$request_uri; #Send to the correct https 
    ssl_certificate /home/example/ssl.cert;
    ssl_certificate_key /home/example/ssl.key;
    }
server {
    listen my_server_IP:443 ssl;
    server_name example.com;
    ssl_certificate /home/example/ssl.cert;
    ssl_certificate_key /home/example/ssl.key;
    <Rest of your config from above, fastcgi etc>
    }
    
por 20.12.2016 / 20:30