Назад | Перейти на главную страницу

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. / пусто /

Когда клиент нажимает: 'example.com/dir/' затем index.html обслуживается.

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

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

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

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

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

Если вы хотите, чтобы 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.