Por que as consultas com uma barra funcionam, mas nenhuma barra final tem 404 na minha configuração Nginx?

1

Contra a configuração abaixo de nginx:

upstream search {
          least_conn;
          server www.google.com:80
              max_fails=1
              fail_timeout=10
              weight=1;
            keepalive 12;
        }
    limit_req_zone $binary_remote_addr zone=search:1m rate=10r/s;

resolver 127.0.0.1;

server {
  listen 80 default_server;
  charset utf-8;
  server_name _;

  access_log /dev/stdout json;

    location @search {
      # Deny requests that do not match allowed methods REGEX
      if ($request_method !~ ^GET$ ) {
        return 405;
      }
      set $proxy_uri $uri;
      if ($proxy_uri ~ ^/[^/]+(/.*)$ ) {
        set $proxy_uri "$1";
      }
      # Deny requests that do not match allowed paths REGEX
      if ($proxy_uri !~ ^.*(\?|$) ) {
        return 403;
      }

      # Rate Limit Requests
      limit_req zone=search burst=10 nodelay;

      # Adding new client_max_body_size service attribute per location
      client_max_body_size 1m;
      proxy_http_version 1.1;
      # Set CORS Headers
      add_header 'Access-Control-Allow-Origin' '*';
      add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS';
      proxy_set_header Origin "";
      proxy_set_header Connection "";
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      proxy_set_header Host $host;
      proxy_set_header X-Real-IP $remote_addr;
      proxy_pass http://search$proxy_uri$is_args$args;
      }

    location /search/ {
      client_max_body_size 1m;
      # send request to the named location for the service
      error_page 418 = @search; return 418;
    }
  # Default location for unmatched requests
  location / {
      return 404;
    }

  location = /health {
    return 200;
  }
}

Rodando

curl -siL  -H 'Host: www.google.com' '127.0.0.1/search/' 

retorna um 200

mas

curl -siL  -H 'Host: www.google.com' '127.0.0.1/search' 

Retorna um 404.

Como faço com e sem a barra de retorno 200?

    
por Josh Beauregard 11.05.2018 / 04:06

1 resposta

0

Eu tive uma experiência semelhante, embora em um ambiente diferente, então você pode precisar testá-lo para verificar. No Apache, por exemplo, se você configurar para permitir CORS (compartilhamento de recursos de origem cruzada), parece funcionar apenas quando houver uma barra à direita. A única explicação que eu poderia fazer para isso era que o servidor precisa ser capaz de dizer explicitamente entre diretórios e arquivos (afinal, um arquivo pode não ter nenhuma extensão e acabar parecendo um diretório, assim como um nome de diretório um ponto e acabam parecendo um arquivo) para permitir ou não o CORS e, consequentemente, quase todas as consultas que você executa em seu servidor. Faça seus testes e verifique se isso é verdade no seu caso.

    
por 10.08.2018 / 08:28

Tags