nginx proxypath https redireciona falha sem barra final

2

Estou tentando configurar o Nginx para encaminhar solicitações para vários serviços de back-end usando proxy_pass.

Os links nas páginas que não têm barras à direita têm https:// na frente, mas são redirecionados para uma solicitação http com uma barra final - que termina em conexão recusada - só quero que esses serviços estejam disponíveis por meio de https. / p>

Então, se um link for muito https://example.com/internal/errorlogs

em um navegador quando carregado https://example.com/internal/errorlogs fornece Error Code 10061: Connection refused (redireciona para http://example.com/internal/errorlogs/ )

Se eu acrescentar manualmente a barra de teste https://example.com/internal/errorlogs/ , ela é carregada

Eu tentei com várias barras à direita anexadas ao proxypath e localização no proxy.conf sem efeito, também adicionei server_name_in_redirect off;

Isso acontece em mais de um aplicativo em nginx e funciona no proxy reverso do apache

Arquivos de configuração;

proxy.conf

location /internal {
    proxy_pass        http://localhost:8081/internal;
    include proxy.inc;
}
.... more entries ....

sites habilitados / main

server {
    listen 443;

    server_name example.com;
    server_name_in_redirect off;

    include proxy.conf;

    ssl on;
}

proxy.inc

proxy_connect_timeout   59s;
proxy_send_timeout      600;
proxy_read_timeout      600;
proxy_buffer_size       64k;
proxy_buffers           16 32k;
proxy_pass_header       Set-Cookie;
proxy_redirect          off;
proxy_hide_header       Vary;

proxy_busy_buffers_size         64k;
proxy_temp_file_write_size      64k;

proxy_set_header        Accept-Encoding         '';
proxy_ignore_headers    Cache-Control           Expires;
proxy_set_header        Referer                 $http_referer;
proxy_set_header        Host                    $host;
proxy_set_header        Cookie                  $http_cookie;
proxy_set_header        X-Real-IP               $remote_addr;
proxy_set_header        X-Forwarded-Host        $host;
proxy_set_header        X-Forwarded-Server      $host;
proxy_set_header        X-Forwarded-For         $proxy_add_x_forwarded_for;
proxy_set_header        X-Forwarded-Ssl         on;
proxy_set_header        X-Forwarded-Proto       https;

saída de curvatura

-$ curl -I -k https://example.com/internal/errorlogs/
HTTP/1.1 200 OK
Server: nginx/1.0.5
Date: Thu, 24 Nov 2011 23:32:07 GMT
Content-Type: text/html;charset=utf-8
Connection: keep-alive
Content-Length: 14327

-$ curl -I -k https://example.com/internal/errorlogs
HTTP/1.1 301 Moved Permanently
Server: nginx/1.0.5
Date: Thu, 24 Nov 2011 23:32:11 GMT
Content-Type: text/html;charset=utf-8
Connection: keep-alive
Content-Length: 127
Location: http://example.com/internal/errorlogs/
    
por Thermionix 24.11.2011 / 02:46

1 resposta

0

Eu vi que você adicionou a diretiva server_name_in_redirect , mas precisa da diretiva proxy_redirect na sessão de localização

link

Você adicionará algo assim

proxy_redirect http://example.com/ /;
    
por 25.11.2011 / 00:38