nginx 404 вместо 403 для пустого каталога

У меня есть следующая конфигурация для моего nginx сервера:

server {
    listen 80 default_server;
    server_name example.com www.example.com;
    root /var/www/example.com/web;

    index index.php index.html;

    location / {
        # try to serve file directly, fallback to rewrite
        try_files $uri $uri/ @rewriteapp;
    }

    location @rewriteapp {
        # rewrite all to index.php
        rewrite ^(.*)$ /index.php last;
    }

    location ~ \.php$ {
        fastcgi_pass unix:/var/run/php5-fpm.sock;
        fastcgi_split_path_info ^(.+\.php)(/.*)$;
        include fastcgi_params;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_param HTTPS off;
        fastcgi_buffer_size 128k;
        fastcgi_buffers 4 256k;
        fastcgi_busy_buffers_size 256k;
    }
}

И следующая структура каталогов:

/var/www/example.com/:

  1. /index.php
  2. /dir/index.html
  3. /empty/

Когда клиент совершает нападки: 'example.com/dir/' затем index.html вручен.

Когда клиент поражает некоторый несуществующий URL как это: 'example.com/non-existent/' затем index.php вручен в корневом каталоге.

Но когда клиент совершает нападки: 'example.com/empty/' затем 403 кода состояния отправляется.

  1. То, почему это отправляет 403, когда 404 более соответствующий индексный файл причины, отсутствует в этом каталоге?
  2. Как я отображаю такие запросы на index.php (@rewriteapp)?
3
задан 5 July 2014 в 11:41
3 ответа
  1. Это происходит потому, что на большинстве веб-серверов действием по умолчанию для папок является "Список каталогов", который отключен по умолчанию. То же самое обычно происходит и в Apache, если вы отключите индексирование папок. В nginx можно поставить =404 в конце директивы try_files.

  2. Это можно сделать, поставив /index.php в конце директивы try_files. Однако, по соображениям безопасности, это не всегда рекомендуется.

Кроме того, в вашей конфигурации есть небольшое недоразумение по поводу nginx: вы должны заменить $uri/ на $uri/index.php или $uri/index.html или что-то в этом роде. Она останавливается на try_files $uri/, потому что находит это место, но пользователю запрещен доступ к нему.

.
11
ответ дан 3 December 2019 в 04:42

Если вы хотите, чтобы nginx отправлял 404 всякий раз, когда в противном случае он отправлял бы 403, это делается с помощью error_page :

server {
    root /var/www/example.com/web;
    error_page 404      /s/404.html;
    error_page 403 =404 /s/404.html;
    location /s/404.html { internal; }

    # etc
}

location заставляет http://example.com/s/404.html также производить 404.

3
ответ дан 3 December 2019 в 04:42

Также есть небольшое недопонимание nginx в вашей конфигурации:вы должны заменить $uri/ на $uri/index.php или $uri/index.html или что-то еще. Он останавливается на try_files $uri/, потому что он находит это место, но пользователю запрещен доступ к нему.

Это работает для меня, так как это было одобрено как правильный ответ:)

Спасибо, Флорин Асэвоайе

location ^~ /folder_of_prefix {
        alias /home/user/html;
           try_files  $uri/index.html  =404;

    }
0
ответ дан 22 October 2021 в 07:52

Теги

Похожие вопросы