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

Автоиндекс nginx не работает

Я пытаюсь поделиться некоторыми из моих личных медиафайлов на своем веб-сайте, но получаю 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/*
  • Tero