Невозможно найти причину 403 Запрещенная ошибка: Nginx Daphne Django - PullRequest
0 голосов
/ 07 марта 2019

У меня было подтверждение в другом вопросе, что я действительно могу запустить приложение Django, используя только Nginx и Daphne, и изменил мой код конфигурации nginx согласно их предложению.

Приложение работает с Дафни на 127.0.0.1:8001

.

Однако я сталкиваюсь с ошибкой 403 Forbidden. Журналы ошибок nginx говорят:

"2019/03/07 11:23:48 [error] 16642#16642: *11 directory index of "/path/to/app" is forbidden, client: xx.xxx.xx.xx, server: app.com, request: "GET / HTTP/1.1", host: "www.app.com", referrer: "http://www.app.com""

Я все еще сталкиваюсь с 403 и был бы благодарен всем, кто может определить местонахождение проблемы.

Мой конфиг nginx

upstream socket {
    ip_hash;
    server 127.0.0.1:8001 fail_timeout=0;
}

server {

    listen 80;
    #listen [::]:80 ipv6only=on;

    server_name your.server.com;
    access_log /etc/nginx/access.log;

    root /var/www/html/someroot;

    location / {
            #autoindex on;

            # First attempt to serve request as file, then
            # as directory, then fall back to displaying a 404.
            # try_files $uri =404;

            #proxy_set_header X-Real-IP $remote_addr;
            #proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            #proxy_set_header Host $http_host;
            #proxy_set_header X-NginX-Proxy true;
            #proxy_pass http://socket;
            #proxy_redirect off;
            #proxy_http_version 1.1;
            #proxy_set_header Upgrade $http_upgrade;
            #proxy_set_header Connection "upgrade";

            #proxy_redirect off;
            #proxy_set_header   X-Forwarded-Proto $scheme;
            #proxy_cache one;
            #proxy_cache_key sfs$request_uri$scheme;
    }

    listen 443 ssl; # managed by Certbot
    ssl_certificate /etc/letsencrypt/live/some/fullchain.pem;
    # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/some/privkey.pem; 
    # managed by Certbot
    include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot

    if ($scheme != "https") {
        return 301 https://$host$request_uri;
    }
}

1 Ответ

0 голосов
/ 07 марта 2019

Мне пришлось изменить try_files $uri=404; на try_files $uri $uri/ =404;, и это решило проблему главной страницы, однако на других страницах по-прежнему отображается ошибка 404.

...