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;
}
Потому что это до /
один, он будет использоваться преимущественно для пути / менеджеров.