Использование системы аутентификации пользователя¶
Этот раздел описывает использование аутентификации пользователя в Django с конфигурацией по умолчанию. Эта конфигурация покрывает требования большинства проектов, предоставляет надежный механизм работы с паролями и правами. Для проектов, которые требуют другой механизм авторизации, Django предоставляет возможность настроить механизм авторизации.
Django предоставляет возможности аутентификации и авторизации пользователей, обычно этот механизм называют системой аутентификации, т.к. эти функции связаны.
Объект пользователя¶
Объекты User - основа системы аутентификации. Они представляют пользователей сайта и используются для проверки прав доступа, регистрации пользователей, ассоциации данных с пользователями. Для представления пользователей в системе аутентификации используется только один класс, таким образом 'суперпользователи' или 'персонал' - это такие же объекты пользователей, просто с определёнными атрибутами.
Основные атрибуты пользователя:
Подробности смотрите в полном описании API, текущий раздел больше ориентирован на использование аутентификации.
Создание пользователей¶
The most direct way to create users is to use the included
create_user() helper function:
>>> from django.contrib.auth.models import User
>>> user = User.objects.create_user('john', 'lennon@thebeatles.com', 'johnpassword')
# At this point, user is a User object that has already been saved
# to the database. You can continue to change its attributes
# if you want to change other fields.
>>> user.last_name = 'Lennon'
>>> user.save()
Если вы используете интерфейс администратора Django, вы можете создать пользователя через UI.
Создание суперпользователя¶
Create superusers using the createsuperuser command:
$ python manage.py createsuperuser --username=joe --email=joe@example.com
Команда попросит ввести пароль. Пользователь будет создан сразу же по завершению команды. Если не указывать :djadminopt:`--username` или :djadminopt:`--email`, команда попросит ввести их.
Смена пароля¶
Django не хранит пароль в открытом виде, хранится только хеш (смотрите раздел о работе с паролями). Поэтому не советуем менять пароль напрямую. Именно по этой причине пользователь создается через специальную функцию.
Пароль можно сменить несколькими способами:
Команда manage.py changepassword *username* позволяет сменить пароль пользователя через консоль. Команда требует ввести пароль дважды. Если введённые значения совпадают, то пароль будет изменен. Если не указать имя пользователя, команда попробует найти пользователя с именем текущего системного пользователя.
Вы можете изменить пароль программно, используя метод set_password():
>>> from django.contrib.auth.models import User
>>> u = User.objects.get(username='john')
>>> u.set_password('new password')
>>> u.save()
Если вы используете интерфейс администратора Django, вы можете изменить пароль, используя админку.
Django также предоставляет представления и формы, которые можно использовать при создании страниц для смены пароля пользователем.
При смене пароля будут завершены все сессии пользователя, если вы используете SessionAuthenticationMiddleware. Смотрите Сброс сессии при изменении пароля.
Аутентификация пользователей¶
- authenticate(request=None, **credentials)¶
Для аутентификации пользователя по имени и паролю используйте
authenticate(). Параметры авторизации передаются как именованные аргументы, по умолчанию этоusernameиpassword, если пароль и имя пользователя верны, будет возвращен объектUser. Если пароль не правильный,authenticate()возвращаетNone. Например:from django.contrib.auth import authenticate user = authenticate(username='john', password='secret') if user is not None: # A backend authenticated the credentials else: # No backend authenticated the credentials
request— это необязательныйHttpRequest, который передается в методеauthenticate()серверов аутентификации.Примечание
Это низкоуровневый API для аутентификации; например, он используется в
RemoteUserMiddleware. Если вы не пишете свою систему авторизации, скорее всего вам не понадобится его использовать. Если вам нужно будет ограничить доступ только авторизованным пользователям, используйте декораторlogin_required().
Аутентификация в веб-запросах¶
Django использует сессию и промежуточный слой для работы системы аутентификации в объекте запроса.
These provide a request.user attribute
on every request which represents the current user. If the current user has not
logged in, this attribute will be set to an instance
of AnonymousUser, otherwise it will be an
instance of User.
Различить их можно с помощью метода is_authenticated():
if request.user.is_authenticated:
# Do something for authenticated users.
...
else:
# Do something for anonymous users.
...
Как авторизовать пользователя¶
Если вы ходите привязать к сессии авторизованного пользователя, используйте функцию login().
- login(request, user, backend=None)¶
Чтобы авторизовать пользователя в представлении, используйте функцию
login(). Она принимает объектHttpRequestи объектUser. Функцияlogin()сохраняет идентификатор пользователя в сессии, используя Django приложение для работы с сессиями.Следует отметить, что любые данные установленные в анонимной сессии будут сохранены в сессии пользователя после его авторизации.
Данные пример показывает как вы можете использовать обе функции
authenticate()иlogin():from django.contrib.auth import authenticate, login def my_view(request): username = request.POST['username'] password = request.POST['password'] user = authenticate(request, username=username, password=password) if user is not None: login(request, user) # Redirect to a success page. ... else: # Return an 'invalid login' error message. ...
Использование системы аутентификации пользователя¶
Когда пользователь входит в систему, идентификатор пользователя и серверная часть, которая использовалась для аутентификации, сохраняются в сеансе пользователя. Это позволяет тому же серверу аутентификации получать данные пользователя при будущем запросе. Серверная часть аутентификации для сохранения в сеансе выбирается следующим образом:
Используйте значение необязательного аргумента
backend, если он предусмотрен.Используйте значение атрибута user.backend, если он присутствует. Это позволяет объединить
authenticate()иlogin():authenticate()устанавливает атрибутuser.backendдля возвращаемого пользовательского объекта.Используйте
backendвAUTHENTICATION_BACKENDS, если он только один.В противном случае вызовите исключение.
В случаях 1 и 2 значение аргумента backend или атрибута user.backend должно быть строкой пути импорта, разделенной точками (например, в AUTHENTICATION_BACKENDS), а не фактическим серверным классом.
Как отменить авторизацию пользователя¶
- logout(request)¶
Для отмены авторизации пользователя, который был авторизован с помощью функции
django.contrib.auth.login(), следует использовать функциюdjango.contrib.auth.logout()в коде вашего представления. Функция принимает объектHttpRequestи не возвращает никаких значений. Например:from django.contrib.auth import logout def logout_view(request): logout(request) # Redirect to a success page.
Следует отметить, что функция
logout()не выбрасывает никаких ошибок, если пользователь не был ранее авторизован.Когда вы вызываете
logout(), данные сеанса для текущего запроса полностью очищаются. Все существующие данные будут удалены. Это сделано для того, чтобы другой человек не мог использовать тот же веб-браузер для входа в систему и доступа к данным сеанса предыдущего пользователя. Если вы хотите поместить в сеанс что-либо, что будет доступно пользователю сразу после выхода из системы, сделайте это после вызоваdjango.contrib.auth.logout().
Ограничение доступа для неавторизованных пользователей¶
Прямой путь¶
Самым простым способом ограничить доступ к страницам является использование метода request.user.is_authenticated() и, при необходимости, перенаправление на страницу авторизации:
from django.conf import settings
from django.shortcuts import redirect
def my_view(request):
if not request.user.is_authenticated:
return redirect('%s?next=%s' % (settings.LOGIN_URL, request.path))
# ...
… или отображение сообщения об ошибке:
from django.shortcuts import render
def my_view(request):
if not request.user.is_authenticated:
return render(request, 'myapp/login_error.html')
# ...
Декоратор login_required¶
- login_required(redirect_field_name='next', login_url=None)¶
Для краткости кода вы можете использовать декоратор
login_required():from django.contrib.auth.decorators import login_required @login_required def my_view(request): ...
Функция
login_required()делает следующее:Если пользователь не авторизован, то перенаправляет его на URL, указанный в параметре конфигурации
settings.LOGIN_URL, передавая текущий абсолютный путь в запросе. Например:/accounts/login/?next=/polls/3/.Если пользователь авторизован, то выполняет код представления. В коде представления не требуется выполнять проверку авторизован ли пользователь или нет.
По умолчанию, в параметре
"next"строки запроса хранится путь, по которому должен быть перенаправлен пользователь в результате успешной аутентификации. Если вам потребуется использовать другое имя для этого параметра, то воспользуйтесь необязательным аргументомredirect_field_nameдекоратораlogin_required():from django.contrib.auth.decorators import login_required @login_required(redirect_field_name='my_redirect_field') def my_view(request): ...
Следует отметить, что если вы воспользуетесь аргументом
redirect_field_name, то вам скорее всего потребуется внести изменения в ваш шаблон авторизации, так как переменная контекста шаблона, которая содержит путь перенаправления, будет использовать значение аргументаredirect_field_nameв качестве своего ключа, а не стандартное значение"next".Декоратор
login_required()также принимает необязательный аргументlogin_url. Например:from django.contrib.auth.decorators import login_required @login_required(login_url='/accounts/login/') def my_view(request): ...
Следует отметить, что если вы не укажите аргумент
login_url, то вам потребуется проверить параметр конфигурацииsettings.LOGIN_URLи ваше представление для авторизации соответственно настроены. Например, пользуясь стандартным поведением, добавьте следующие строки к вашей схеме URL:from django.contrib.auth import views as auth_views path('accounts/login/', auth_views.LoginView.as_view()),
Параметр конфигурации
settings.LOGIN_URLтакже принимает имена представлений и именованные шаблоны URL. Это позволяет вам свободно переносить ваше представление для авторизации пользователя внутри схемы URL без необходимости изменения настроек.
Примечание
Декоратор login_required() не проверяет свойство is_active объекта пользователя.
См.также
Если вы создаёте собственные представления для интерфейса администратора (или вам нужна та же аутентификация, что используются встроенными представлениями), то вам может пригодиться декоратор django.contrib.admin.views.decorators.staff_member_required() в качестве полезной альтернативы login_required().
The LoginRequired mixin¶
При использовании CBV представлений, вы можете получить поведение аналогичное login_required, используя примесь LoginRequiredMixin. Эта примесь должна быть указана в самом начале списка наследования.
- class LoginRequiredMixin¶
Если представление использует эту примесь, все запросы от неаутентифицированных пользователей будут перенаправлены на страницу аутентификации или будет показана ошибка HTTP 403 Forbidden, это зависит от параметра
raise_exception.Вы можете установить любой из параметров
AccessMixinдля управления обработкой неаутентифицированных пользователей:from django.contrib.auth.mixins import LoginRequiredMixin class MyView(LoginRequiredMixin, View): login_url = '/login/' redirect_field_name = 'redirect_to'
Примечание
Подобно декоратору login_required(), эта примесь не проверяет свойство is_active объекта пользователя.
Ограничение доступа для авторизованных пользователей с помощью дополнительной проверки¶
Для ограничения доступа пользователям на основе определённых прав или какой-либо другой проверке, вам следует выполнять те же действия, что описаны выше.
Самым простым способом будет выполнение вашей проверки над request.user прямо в представлении. Например, эта проверка в представлении проверяет, что пользователь имеет адрес электронной почты на требуемом домене и, если это не так, перенаправляет его на страницу авторизации:
from django.shortcuts import redirect
def my_view(request):
if not request.user.email.endswith('@example.com'):
return redirect('/login/?next=%s' % request.path)
# ...
- user_passes_test(test_func, login_url=None, redirect_field_name='next')¶
Для удобства вы можете использовать декоратор
user_passes_test, который выполняет перенаправление в случае, если проверяющая функция возвращаетFalse:from django.contrib.auth.decorators import user_passes_test def email_check(user): return user.email.endswith('@example.com') @user_passes_test(email_check) def my_view(request): ...
Декоратор
user_passes_test()принимает обязательный аргумент: функцию, которая принимает объектUserи возвращаетTrue, если пользователю разрешён доступ к просмотру страницы. Следует отметить, что декораторuser_passes_test()не выполняет автоматически проверку, чтоUserпрошёл авторизацию.Декоратор
user_passes_test()принимает для необязательных аргумента:login_urlПозволяет определеть URL на который будут перенаправляться пользователя, которые нее смогут пройти проверку. Это может быть страница авторизации или по умолчанию это будет значение параметра конфигурации
settings.LOGIN_URL, если вы не указали никакого значения.redirect_field_nameАналогично декоратору
login_required(). Присвоение значенияNoneудаляет соответствующее поле из URL, что может вам потребоваться при перенаправлении пользователей, которые не прошли проверку, на страницу отличную от страницы авторизации.
Например:
@user_passes_test(email_check, login_url='/login/') def my_view(request): ...
- class UserPassesTestMixin¶
При использовании CBV представлений, вы можете для этой цели применять
UserPassesTestMixin.- test_func()¶
Вы можете переопределить метод
test_func()класса для того, чтобы указать тест, который будет выполнен. Далее, вы можете указать любой параметрAccessMixinдля настройки обработки неаутентифицированных пользователей:from django.contrib.auth.mixins import UserPassesTestMixin class MyView(UserPassesTestMixin, View): def test_func(self): return self.request.user.email.endswith('@example.com')
- get_test_func()¶
Вы также можете переопределить метод
get_test_func(), чтобы заставить примесь использовать по-другому именованную функцию для выполнения проверки (вместоtest_func()).
Цепочка из
UserPassesTestMixinИз-за особенностей реализации
UserPassesTestMixin, вы не можете выстроить цепочку наследования. Следующий пример не работает:class TestMixin1(UserPassesTestMixin): def test_func(self): return self.request.user.email.endswith('@example.com') class TestMixin2(UserPassesTestMixin): def test_func(self): return self.request.user.username.startswith('django') class MyView(TestMixin1, TestMixin2, View): ...
Если
TestMixin1вызоветsuper()и примет результат в работу, тоTestMixin1не будет больше работать в одиночку.
Декоратор permission_required¶
- permission_required(perm, login_url=None, raise_exception=False)¶
It’s a relatively common task to check whether a user has a particular permission. For that reason, Django provides a shortcut for that case: the
permission_required()decorator.:from django.contrib.auth.decorators import permission_required @permission_required('polls.add_choice') def my_view(request): ...
Как и в случае с методом
has_perm(), имена разрешений принимают форму"<метка приложения>.<кодовое имя разрешения>"(т. е.polls.add_choiceдля разрешения на модель в приложенииpolls).Декоратор также может принимать перечисление прав, в этом случае пользователь должен обладать всеми правами для того, чтобы получить доступ к представлению.
Следует отметить, что декоратор
permission_required()также принимает необязательный аргументlogin_url:from django.contrib.auth.decorators import permission_required @permission_required('polls.add_choice', login_url='/loginpage/') def my_view(request): ...
Аналогично декоратору
login_required(), по умолчанию значение для аргументаlogin_urlсоответствует значению параметра конфигурацииsettings.LOGIN_URL.Если определён аргумент
raise_exception, то декоратор будет выбрасывать исключениеPermissionDeniedс описанием 403 (HTTP Forbidden) представление вместо перенаправления на страницу авторизации.Если вам надо использовать
raise_exception, но также предоставить пользователям шанс сначала аутентифицироваться, вы можете использовать декораторlogin_required():from django.contrib.auth.decorators import login_required, permission_required @login_required @permission_required('polls.add_choice', raise_exception=True) def my_view(request): ...
Это также позволяет избежать цикла перенаправления, когда
LoginView``s ``redirect_authenticated_user=True`и вошедший в систему пользователь не имеет всех необходимых разрешений.
Примесь PermissionRequiredMixin¶
Для того, чтобы выполнить проверки для CBV представлений, вы можете использовать PermissionRequiredMixin:
- class PermissionRequiredMixin¶
Эта примесь, подобно декоратору
permisison_required, проверяет, есть ли у пользователя, который пытается получить доступ к представлению, все необходимые права. Вы можете указать право (или перечисление прав) с помощью параметраpermission_required:from django.contrib.auth.mixins import PermissionRequiredMixin class MyView(PermissionRequiredMixin, View): permission_required = 'polls.add_choice' # Or multiple of permissions: permission_required = ('polls.view_choice', 'polls.change_choice')
Вы можете установить любые параметры
AccessMixinдля изменения обработки неаутентифированных пользователей.Вы также можете переопределить эти методы:
- get_permission_required()¶
Возвращает перечисления имён прав, используемых примесью. По умолчанию, это содержимое атрибута
permission_required, при необходимости преобразованное в кортеж.
- has_permission()¶
Возвращает булево значение, есть ли у текущего пользователя право выполнить декорированное представление. По умолчанию, возвращается результат вызова метода
has_perms()со списком прав, полученных от методаget_permission_required().
Представления аутентификации¶
Django предоставляет несколько представлений, с помощью которых вы можете осуществлять управление авторизацией пользователей и их паролями. Представления используют ряд соответствующих форм, но вы можете передавать и свои формы.
Django не предоставляет стандартного шаблона для представлений аутентификации. Вы должны создать свой собственный шаблон для представлений, которые планируете использовать. Шаблонный контекст описан в каждом представлении, обратитесь к Все представления для аутентификации.
Использование представлений¶
Существует несколько разных методов для реализации данных представлений в вашем проекте. Самым простым способом будет подключение схемы URL из django.contrib.auth.urls в вашу схему, например:
urlpatterns = [
path('accounts/', include('django.contrib.auth.urls')),
]
This will include the following URL patterns:
accounts/login/ [name='login']
accounts/logout/ [name='logout']
accounts/password_change/ [name='password_change']
accounts/password_change/done/ [name='password_change_done']
accounts/password_reset/ [name='password_reset']
accounts/password_reset/done/ [name='password_reset_done']
accounts/reset/<uidb64>/<token>/ [name='password_reset_confirm']
accounts/reset/done/ [name='password_reset_complete']
Представления добавляют имя для URL для упрощения ссылок на них. Обратитесь к документации на URL для получения детальной информации по использованию именованных шаблонов URL.
Если вам требуется больше контроля над вашими URL, вы можете указывать специальное представление в вашей схеме URL:
from django.contrib.auth import views as auth_views
urlpatterns = [
path('change-password/', auth_views.PasswordChangeView.as_view()),
]
Представления принимают необязательные аргументы, которые вы можете использовать для изменения их поведения. Например, если требуется изменить имя шаблона, который будет использоваться представлением, вы можете указать аргумент template_name. Для этого надо указать именованные аргументы в схеме URL и они будут переданы в представление. Например:
urlpatterns = [
path(
'change-password/',
auth_views.PasswordChangeView.as_view(template_name='change-password.html'),
),
]
При использовании CBV представлений, вы можете для этой цели применять UserPassesTestMixin.
Все представления для аутентификации¶
Ниже приведён список со всеми представлениями пакета django.contrib.auth. Для получения информации о деталях реализации обратитесь к Использование представлений.
- class LoginView¶
Имя URL:
loginОбратитесь к документации на URL для получения информации по использованию именованных шаблонов URL.
Атрибуты:
template_name: The name of a template to display for the view used to log the user in. Defaults toregistration/login.html.redirect_field_name: The name of aGETfield containing the URL to redirect to after login. Defaults tonext.authentication_form: A callable (typically a form class) to use for authentication. Defaults toAuthenticationForm.extra_context: A dictionary of context data that will be added to the default context data passed to the template.redirect_authenticated_user: A boolean that controls whether or not authenticated users accessing the login page will be redirected as if they had just successfully logged in. Defaults toFalse.Предупреждение
Если вы включите redirect_authenticated_user, другие веб-сайты смогут определять, аутентифицированы ли их посетители на вашем сайте, запрашивая URL-адреса перенаправления на файлы изображений на вашем веб-сайте. Чтобы избежать утечки информации о «отпечатках пальцев в социальных сетях <https://robinlinus.github.io/socialmedia-leak/>`_», разместите все изображения и свой значок на отдельном домене.
Включение redirect_authenticated_user также может привести к циклу перенаправления при использовании декоратора
permission_required(), если не используется параметрraise_Exception.success_url_allowed_hosts: Asetof hosts, in addition torequest.get_host(), that are safe for redirecting after login. Defaults to an emptyset.
Вот, что делает представление
django.contrib.auth.views.login:При вызове через
GET, оно отображает форму для аутентификации, которая отправляет введённые данные через POST на тот же URL. Подробности далее.При вызове через
POSTс аутентификационными данными пользователя, оно пытается авторизовать пользователя. При успешной авторизации, представление перенаправляет на URL, указанный вnext. Если параметрnextне был предоставлен, происходит перенаправление на URL, содержащийся в параметре конфигурацииsettings.LOGIN_REDIRECT_URL(по умолчанию,/accounts/profile/). При невозможности авторизации, представление снова показывает форму.
Вашей обязанностью является предоставление HTML кода для шаблона, который по умолчанию называется
registration/login.html. Данный шаблон принимает через контекст четыре переменных:form: ОбъектForm, который представляетAuthenticationForm.next: URL, на который будет осуществлено перенаправление после успешной авторизации. Можно также передавать строку запроса.site: ТекущийSite, соответствующий параметру конфигурацииSITE_ID. Если вы не активировали соответствующее приложение, переменной будет присвоен экземплярRequestSite, который получает имя сайта и домен из текущегоHttpRequest.site_name: Псевдоним дляsite.name. Если вы не активировали соответствующее приложение, переменной будет присвоено значениеrequest.META['SERVER_NAME']. Для подробностей о работе с сайтами обратитесь к Фреймворк для сайтов.
Если потребуется отказаться от вызова шаблона
registration/login.html, вы можете передать в представление параметрtemplate_nameчерез дополнительные аргументы URL с вашей схеме. Например, эта строка URL будет использовать шаблонmyapp/login.html:path('accounts/login/', auth_views.LoginView.as_view(template_name='myapp/login.html')),
Вы также можете указать имя для
GETполя, которое будет содержать URL для перенаправления после успешной авторизации пользователя, передав его в аргументеredirect_field_nameв представление. По умолчанию,next.Здесь показан пример содержимого шаблона
registration/login.html, который вы можете использовать в качестве отправной точки. Он предполагает, что у вас есть шаблонbase.html, который определяет блокcontent:{% extends "base.html" %} {% block content %} {% if form.errors %} <p>Your username and password didn't match. Please try again.</p> {% endif %} {% if next %} {% if user.is_authenticated %} <p>Your account doesn't have access to this page. To proceed, please login with an account that has access.</p> {% else %} <p>Please login to see this page.</p> {% endif %} {% endif %} <form method="post" action="{% url 'login' %}"> {% csrf_token %} <table> <tr> <td>{{ form.username.label_tag }}</td> <td>{{ form.username }}</td> </tr> <tr> <td>{{ form.password.label_tag }}</td> <td>{{ form.password }}</td> </tr> </table> <input type="submit" value="login"> <input type="hidden" name="next" value="{{ next }}"> </form> {# Assumes you setup the password_reset view in your URLconf #} <p><a href="{% url 'password_reset' %}">Lost password?</a></p> {% endblock %}
Если у вас реализован собственный механизм аутентификации (обратитесь к Собственная аутентификация) вы можете передать свою форму аутентификации в представление через параметр
authentication_form. Данная форма должна принимать именованный аргументrequestв её методе__init__и предоставлять методget_user, который должен возвращать объект аутентифицированного пользователя (метод будет вызываться только после успешной аутентификации).
- class LogoutView¶
Logs a user out.
Имя URL:
logoutАтрибуты:
next_page: The URL to redirect to after logout. Defaults tosettings.LOGOUT_REDIRECT_URL.template_name: The full name of a template to display after logging the user out. Defaults toregistration/logged_out.html.redirect_field_name: The name of aGETfield containing the URL to redirect to after log out. Defaults tonext. Overrides thenext_pageURL if the givenGETparameter is passed.extra_context: A dictionary of context data that will be added to the default context data passed to the template.success_url_allowed_hosts: Asetof hosts, in addition torequest.get_host(), that are safe for redirecting after logout. Defaults to an emptyset.
Контекст шаблона:
title: Локализованная строка «Logged out».site: ТекущийSite, соответствующий параметру конфигурацииSITE_ID. Если вы не активировали соответствующее приложение, переменной будет присвоен экземплярRequestSite, который получает имя сайта и домен из текущегоHttpRequest.site_name: Псевдоним дляsite.name. Если вы не активировали соответствующее приложение, переменной будет присвоено значениеrequest.META['SERVER_NAME']. Для подробностей о работе с сайтами обратитесь к Фреймворк для сайтов.
- logout_then_login(request, login_url=None)¶
Logs a user out, then redirects to the login page.
Имя URL: Значения по умолчанию нет
Необязательные аргументы:
login_url: URL страницы авторизации, на которую будет выполнено перенаправление. По умолчанию,settings.LOGIN_URL.
- class PasswordChangeView¶
Имя URL:
password_changeПозволяет пользователю изменить его пароль.
Атрибуты:
template_name: The full name of a template to use for displaying the password change form. Defaults toregistration/password_change_form.htmlif not supplied.success_url: The URL to redirect to after a successful password change. Defaults to'password_change_done'.form_class: A custom «change password» form which must accept auserkeyword argument. The form is responsible for actually changing the user’s password. Defaults toPasswordChangeForm.extra_context: A dictionary of context data that will be added to the default context data passed to the template.
Контекст шаблона:
form: Форма для изменения пароля (обратитесь кpassword_change_formвыше).
- class PasswordChangeDoneView¶
Имя URL:
password_change_doneСтраница, отображаемая после того, как пользователь изменил свой пароль.
Атрибуты:
template_name: The full name of a template to use. Defaults toregistration/password_change_done.htmlif not supplied.extra_context: A dictionary of context data that will be added to the default context data passed to the template.
- class PasswordResetView¶
Имя URL:
password_resetПозволяет пользователю сбросить свой пароль, генерируя одноразовую ссылку, которая может быть использована для сброса пароля, и отправляя её на зарегистрированную электронную почто пользователя.
If the email address provided does not exist in the system, this view won’t send an email, but the user won’t receive any error message either. This prevents information leaking to potential attackers. If you want to provide an error message in this case, you can subclass
PasswordResetFormand use theform_classattribute.Примечание
Be aware that sending an email costs extra time, hence you may be vulnerable to an email address enumeration timing attack due to a difference between the duration of a reset request for an existing email address and the duration of a reset request for a nonexistent email address. To reduce the overhead, you can use a 3rd party package that allows to send emails asynchronously, e.g. django-mailer.
Users flagged with an unusable password (see
set_unusable_password()aren’t allowed to request a password reset to prevent misuse when using an external authentication source like LDAP. Note that they won’t receive any error message since this would expose their account’s existence but no mail will be sent either.Атрибуты:
template_name: The full name of a template to use for displaying the password reset form. Defaults toregistration/password_reset_form.htmlif not supplied.form_class: Form that will be used to get the email of the user to reset the password for. Defaults toPasswordResetForm.email_template_name: The full name of a template to use for generating the email with the reset password link. Defaults toregistration/password_reset_email.htmlif not supplied.subject_template_name: The full name of a template to use for the subject of the email with the reset password link. Defaults toregistration/password_reset_subject.txtif not supplied.token_generator: Instance of the class to check the one time link. This will default todefault_token_generator, it’s an instance ofdjango.contrib.auth.tokens.PasswordResetTokenGenerator.success_url: The URL to redirect to after a successful password reset request. Defaults to'password_reset_done'.from_email: A valid email address. By default Django uses theDEFAULT_FROM_EMAIL.extra_context: A dictionary of context data that will be added to the default context data passed to the template.html_email_template_name: The full name of a template to use for generating a text/html multipart email with the password reset link. By default, HTML email is not sent.extra_email_context: A dictionary of context data that will be available in the email template. It can be used to override default template context values listed below e.g.domain.
Контекст шаблона:
form: Форма (смотритеpassword_reset_formвыше) для сброса пароля пользователя.
Контекст шаблона электронной почты:
email: Псевдоним дляuser.emailuser: ТекущийUser, соответствующий полюemailформы. Толька активные пользователи имеют возможность сбрасывать свои пароли passwords (User.is_active is True).site_name: Псевдоним дляsite.name. Если вы не активировали соответствующее приложение, переменной будет присвоено значениеrequest.META['SERVER_NAME']. Для подробностей о работе с сайтами обратитесь к Фреймворк для сайтов.domain: Псевдоним дляsite.domain. Если вы не используете приложение для работы с сайтами, то значением будетrequest.get_host().protocol: http или httpsuid: Первичный ключ пользователя, закодированный в base 64.token: Токен для проверки корректности ссылки для сброса пароля.
Пример
registration/password_reset_email.html(шаблон тела письма):Someone asked for password reset for email {{ email }}. Follow the link below: {{ protocol}}://{{ domain }}{% url 'password_reset_confirm' uidb64=uid token=token %}
Такой же контекст используется для шаблона заголовка сообщения. Заголовок должен быть представлен одной строкой простого текста.
- class PasswordResetDoneView¶
Имя URL:
password_reset_doneЭта страница отображается после отправки пользователю письма с ссылкой для сброса его пароля. Данное представление вызывается по умолчанию, если представлению
password_reset()не было явно передан URLpost_reset_redirect.Примечание
Если предоставленный адрес электронной почты не существует в системе, пользователь не активирован или имеет деактивированный пароль, то пользователь будет перенаправляться на это представление, но никаких писем ему отправляться не будет.
Атрибуты:
template_name: The full name of a template to use. Defaults toregistration/password_reset_done.htmlif not supplied.extra_context: A dictionary of context data that will be added to the default context data passed to the template.
- class PasswordResetConfirmView¶
Имя URL:
password_reset_confirmПредставляет форму для ввода нового пароля.
Обязательные аргументы:
uid: Первичный ключ пользователя, закодированный в base 64.token: Токен для проверки корректности ссылки для сброса пароля.
Атрибуты:
template_name: The full name of a template to display the confirm password view. Default value isregistration/password_reset_confirm.html.token_generator: Instance of the class to check the password. This will default todefault_token_generator, it’s an instance ofdjango.contrib.auth.tokens.PasswordResetTokenGenerator.post_reset_login: A boolean indicating if the user should be automatically authenticated after a successful password reset. Defaults toFalse.post_reset_login_backend: A dotted path to the authentication backend to use when authenticating a user ifpost_reset_loginisTrue. Required only if you have multipleAUTHENTICATION_BACKENDSconfigured. Defaults toNone.form_class: Form that will be used to set the password. Defaults toSetPasswordForm.success_url: URL to redirect after the password reset done. Defaults to'password_reset_complete'.extra_context: A dictionary of context data that will be added to the default context data passed to the template.reset_url_token: Token parameter displayed as a component of password reset URLs. Defaults to'set-password'.
Контекст шаблона:
form: Форма (смотритеpassword_reset_formвыше) для сброса пароля пользователя.validlink: Булево значение. True, если ссылка (комбинацияuidb64иtoken) корректна и не была ещё использована.
- class PasswordResetCompleteView¶
Имя URL:
password_reset_completeПредставление, которое информирует пользователя об успешном изменении пароля.
Атрибуты:
template_name: The full name of a template to display the view. Defaults toregistration/password_reset_complete.html.extra_context: A dictionary of context data that will be added to the default context data passed to the template.
Вспомогательные функции¶
- redirect_to_login(next, login_url=None, redirect_field_name='next')¶
Перенаправляет на страницу аутентификации и, в случае её успешного прохождения, затем перебрасывает на другой URL.
Обязательные аргументы:
next: URL на который происходит перенаправление после успешной авторизации.
Необязательные аргументы:
login_url: URL страницы авторизации, на которую будет выполнено перенаправление. По умолчанию,settings.LOGIN_URL.redirect_field_name: The name of aGETfield containing the URL to redirect to after log out. Overridesnextif the givenGETparameter is passed.
Встроенные формы¶
Если вы не желаете использовать встроенные представления, но и формы переписывать не хотите, то система аутентификации предоставляет несколько встроенных форм, расположенных в django.contrib.auth.forms:
Примечание
Встроенные формы делают некоторые предположения о модели пользователя, с которой они работают. Если вы используете собственную модель пользователя, может потребоваться определить собственные формы для системы аутентификации. Больше информации можно получить в документации на использование встроенных форм аутентификации для собственной модели пользователя.
- class AdminPasswordChangeForm¶
A form used in the admin interface to change a user’s password.
Принимает
userв качестве первого неименованного параметра.
- class AuthenticationForm¶
Форма для аутентификации пользователя.
Принимает
requestв качестве первого неименованного аргумента, который сохраняется в экземпляре формы для использования подклассами.- confirm_login_allowed(user)¶
По умолчанию, форма
AuthenticationFormигнорирует пользователей у которых флагis_activeустановлен вFalse. Вы можете изменить это поведение на проверку некого права пройти аутентификацию для пользователей. Выполните это с помощью своей формы, которая унаследована отAuthenticationFormи переопределяет методconfirm_login_allowed(). Этот метод должен выбрасывать исключениеValidationErrorв случае, если указанный пользователь не может проходить аутентификацию.Например, позволяем всем пользователям проходить аутентификацию, невзирая на их статус активности:
from django.contrib.auth.forms import AuthenticationForm class AuthenticationFormWithInactiveUsersOkay(AuthenticationForm): def confirm_login_allowed(self, user): pass
(В этом случае вам также потребуется использовать серверную часть аутентификации, которая разрешает неактивным пользователям, например
AllowAllUsersModelBackend.)Или позволяем только некоторым активным пользователям проходить аутентификацию:
class PickyAuthenticationForm(AuthenticationForm): def confirm_login_allowed(self, user): if not user.is_active: raise ValidationError( _("This account is inactive."), code='inactive', ) if user.username.startswith('b'): raise ValidationError( _("Sorry, accounts starting with 'b' aren't welcome here."), code='no_b_users', )
- class PasswordChangeForm¶
Форма, через которую пользователь может менять свой пароль.
- class PasswordResetForm¶
Форма для генерации и отправки одноразовой ссылки для сброса пользовательского пароля.
- send_mail(subject_template_name, email_template_name, context, from_email, to_email, html_email_template_name=None)¶
Uses the arguments to send an
EmailMultiAlternatives. Can be overridden to customize how the email is sent to the user.- Параметры:
subject_template_name – шаблон для заголовка.
email_template_name – шаблон для тела письма.
context – контекст передаётся в
subject_template,email_templateиhtml_email_template(если он неNone).from_email – адрес электронной почты отправителя.
to_email – адрес электронной почты пользователя.
html_email_template_name – шаблон для HTML тела письма, по умолчанию,
None, в этом случае отсылается обычный текст.
По умолчанию,
save()наполняетcontextтеми же переменными, что и функцияpassword_reset(), передавая их в контекст электронного сообщения.
- class SetPasswordForm¶
Форма, которая позволяет пользователю изменять свой пароль без ввода старого пароля.
- class UserChangeForm¶
Форма, используемая в интерфейсе администратора для изменения информации о пользователе и его списка прав.
- class UserCreationForm¶
A
ModelFormfor creating a new user.Он имеет три поля:
имя пользователя(из модели пользователя),пароль1ипароль2. Он проверяет совпадениеpassword1иpassword2, проверяет пароль с помощьюvalidate_password()и устанавливает пароль пользователя с помощьюset_password().
Аутентификационные данные в шаблонах¶
Авторизованный пользователь и его права доступны в шаблонном контексте при использовании RequestContext.
Техническая особенность
Технически, эти переменные становятся доступными в шаблонном контексте, только если вы используете RequestContext и активирован контекстный процессор 'django.contrib.auth.context_processors.auth'. По умолчанию проект так и настроен. Больше информации можно найти в документации на RequestContext.
Пользователи¶
При рендеринге RequestContext, авторизованный пользователь, неважно будет это экземпляр User или AnonymousUser, сохраняется в шаблонной переменной {{ user }}:
{% if user.is_authenticated %}
<p>Welcome, {{ user.username }}. Thanks for logging in.</p>
{% else %}
<p>Welcome, new user. Please log in.</p>
{% endif %}
Эта шаблонная переменная не доступна, если не используется RequestContext.
Права¶
Права авторизованного пользователя хранятся в шаблонной переменной {{ perms }}. Она связана с экземпляром django.contrib.auth.context_processors.PermWrapper, который реализует доступ к правам.
Evaluating a single-attribute lookup of {{ perms }} as a boolean is a proxy
to User.has_module_perms(). For example, to check if
the logged-in user has any permissions in the foo app:
{% if perms.foo %}
Evaluating a two-level-attribute lookup as a boolean is a proxy to
User.has_perm(). For example,
to check if the logged-in user has the permission foo.add_vote:
{% if perms.foo.add_vote %}
Вот более полный пример проверки разрешений в шаблоне:
{% if perms.foo %}
<p>You have permission to do something in the foo app.</p>
{% if perms.foo.add_vote %}
<p>You can vote!</p>
{% endif %}
{% if perms.foo.add_driving %}
<p>You can drive!</p>
{% endif %}
{% else %}
<p>You don't have permission to do anything in the foo app.</p>
{% endif %}
Также позможен поиск прав с помощью выражения {% if in %}. Например:
{% if 'foo' in perms %}
{% if 'foo.add_vote' in perms %}
<p>In lookup works, too.</p>
{% endif %}
{% endif %}
Управление пользователями в интерфейсе администратора¶
Если вы подключили к проекту django.contrib.admin и django.contrib.auth, интерфейс администратора предоставляет удобный способ для просмотра и управления пользователями, группами и правами. Пользователи могут быть созданы и удалены как любая другая модель Django. Группы могут быть созданы и права могут быть назначены на пользователей и группы. Журнал изменений, выполненных через интерфейс администратора, сохраняется и доступен.
Создание пользователей¶
You should see a link to «Users» in the «Auth» section of the main admin index page. The «Add user» admin page is different than standard admin pages in that it requires you to choose a username and password before allowing you to edit the rest of the user’s fields.
Также следует отметить, что если вам нужен пользоватедль, который бы позволил создавать пользователей с помощью интерфейса администратора, вам следует дать ему право на добавление пользователей и право на изменение пользователей (т.е., права «Добавить пользователя» и «Изменить пользователя»). Если пользователь обладает правом создания пользователей, но не имеет права на их редактирование, тогда он не сможет создавать пользователей. Почему? Потому что, если у вас есть право на создание пользователей, у вас есть возможность создать суперпользователей, которые могут в свою очередь, изменять других пользователей. Таким образом, Django требует наличие прав на добавление и изменение пользователей в целях безопасности.
Продумайте как вы позволяете управлять правами. Если вы предоставите обычному пользователю право на редактирование пользователей, это будет означать то же самое, что и предоставление ему прав суперпользователя, так как он сможет повысить права пользователей, включая себя!
Смена пароля¶
User passwords are not displayed in the admin (nor stored in the database), but the password storage details are displayed. Included in the display of this information is a link to a password change form that allows admins to change user passwords.