Nginx авторизация только для данного местоположения

Я использую Nginx в качестве обратного прокси-сервера для веб-приложения Python WSGI.

Это выглядит примерно так:

location / {
    #auth_basic     "Administrator Login";
    #auth_basic_user_file  /var/www/static/.htpasswd;
    proxy_pass          http://mywebapp_gunicorn;
    proxy_redirect      off;
    proxy_set_header    Host            $host;
    proxy_set_header    X-Real-IP       $remote_addr;
    proxy_set_header    X-Forwarded-For $proxy_add_x_forwarded_for;
}

Внутри веб-приложения у меня есть несколько страниц администратора, которые я хотел бы защитить, поэтому теперь я использую некоторую аутентификацию внутри веб-приложения, чтобы защитить их, и я бы хотел добавить аутентификацию Nginx.

Как активировать:

    auth_basic      "Administrator Login";
    auth_basic_user_file  /var/www/static/.htpasswd;

Для пути: /managers, но не для всех других URL.

1 ответ

Решение

Вам просто нужно добавить еще один блок местоположения перед тем, который у вас есть, чтобы соответствовать URL, который вы хотите защитить.

location /managers {
    auth_basic      "Administrator Login";
    auth_basic_user_file  /var/www/static/.htpasswd;
    proxy_pass          http://mywebapp_gunicorn;
    proxy_redirect      off;
    proxy_set_header    Host            $host;
    proxy_set_header    X-Real-IP       $remote_addr;
    proxy_set_header    X-Forwarded-For $proxy_add_x_forwarded_for;
}

location / {
    proxy_pass          http://mywebapp_gunicorn;
    proxy_redirect      off;
    proxy_set_header    Host            $host;
    proxy_set_header    X-Real-IP       $remote_addr;
    proxy_set_header    X-Forwarded-For $proxy_add_x_forwarded_for;
}

Потому что это до / один, он будет использоваться преимущественно для пути / менеджеров.

Другие вопросы по тегам