У меня есть следующая конфигурация для моего 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/:
Когда клиент совершает нападки: 'example.com/dir/' затем index.html вручен.
Когда клиент поражает некоторый несуществующий URL как это: 'example.com/non-existent/' затем index.php вручен в корневом каталоге.
Но когда клиент совершает нападки: 'example.com/empty/' затем 403 кода состояния отправляется.
Это происходит потому, что на большинстве веб-серверов действием по умолчанию для папок является "Список каталогов", который отключен по умолчанию. То же самое обычно происходит и в Apache, если вы отключите индексирование папок. В nginx можно поставить =404 в конце директивы try_files.
Это можно сделать, поставив /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.
Также есть небольшое недопонимание 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;
}