Я пытаюсь поделиться некоторыми из моих личных медиафайлов на своем веб-сайте, но получаю 403 Запрещено ошибка, когда я пытаюсь перейти к нему (www.example.com/media). Однако, когда я указываю полный путь к файлу, например, www.example.com/media/2001/golden_retriever.jpg, я вижу реальное изображение.
Я включил autoindex on;
в /etc/nginx/sites-available/example.com вот так:
location /media {
allow all;
autoindex on;
}
После перезапуска с service nginx restart
, Я получаю ту же ошибку. Я пробовал поставить autoindex on;
в location / { }
и внутри фактического server { }
блокировать безрезультатно. По сути, при перезапуске сервера nginx после изменений ничего не происходит.
Конфигурация для всех сайтов:
server {
listen 80; ## listen for ipv4; this line is default and implied
#listen [::]:80 default ipv6only=on; ## listen for ipv6
root /usr/share/nginx/www/example;
index index.php index.html index.htm;
# Make site accessible from http://localhost/
server_name example.com www.example.com;
location / {
# First attempt to serve request as file, then
# as directory, then fall back to index.html
try_files $uri $uri/ /index.html;
# Uncomment to enable naxsi on this location
# include /etc/nginx/naxsi.rules
}
location /doc/ {
alias /usr/share/doc/;
autoindex on;
allow 127.0.0.1;
deny all;
}
location /media {
allow all;
autoindex on;
}
# Only for nginx-naxsi : process denied requests
#location /RequestDenied {
# For example, return an error code
#return 418;
#}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
#error_page 500 502 503 504 /50x.html;
#location = /50x.html {
# root /usr/share/nginx/www;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
location ~ \.php$ {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
# NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini
# With php5-cgi alone:
#fastcgi_pass unix:/var/run/php5-fpm.sock;
# With php5-fpm:
fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_index index.php;
include fastcgi_params;
}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
}
Обратите внимание, что в этой конфигурации есть символическая ссылка на сайты с тем же именем.
Похоже, здесь виновата символическая ссылка. При создании символической ссылки используйте полный путь вместо относительный путь вот так:
ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enable/example.com
Вы уверены, что каталог /usr/share/nginx/www/example/media
настроены ли разрешения, чтобы процесс веб-сервера мог получить доступ к каталогу?
Если вы создали каталог через свою учетную запись пользователя, вам необходимо убедиться, что другая группа разрешений имеет разрешения на чтение и выполнение в этом каталоге.
chmod a+rx /usr/share/nginx/www/example/media
добавляет в каталог права на чтение / выполнение.
Кроме того, файлы в каталоге должны иметь права на чтение для другой группы:
chmod a+r /usr/share/nginx/www/example/media/*