Шаблон login
Когда пользователь запрашивает страницу входа, Django использует свое представление login по умолчанию, но мы все равно должны предоставить шаблон для этой страницы. В каталоге learning_log/users/ создайте каталог с именем templates, а внутри него — еще один каталог с именем users. Вот как выглядит шаблон login.html, который должен находиться в learning_log/users/templates/users/:
login.html
{% extends "learning_logs/base.html" %}
{% block content %}
(1) {% if form.errors %}
<p>Your username and password didn't match. Please try again.</p>
{% endif %}
. .
(2) <form method="post" action="{% url 'users:login' %}">
{% csrf_token %}
(3) {{ form.as_p }}
. .
(4) <button name="submit">log in</button>
(5) <input type="hidden" name="next" value="{% url 'learning_logs:index' %}" />
</form>
. .
{% endblock content %}
Шаблон расширяет base.html, чтобы страница входа по оформлению и поведению была похожа на другие страницы сайта. Обратите внимание: шаблон в одном приложении может расширять шаблон из другого приложения.
Если у формы установлен атрибут errors, выводится сообщение об ошибке (1) . В нем говорится, что комбинация имени пользователя и пароля не соответствует информации, хранящейся в базе данных.
Мы хотим, чтобы представление обработало форму, поэтому аргументу action присваивается URL страницы входа (2). Представление отправляет форму шаблону, мы должны вывести форму (3) и добавить кнопку отправки данных (4). В точке (5) включается скрытый элемент формы 'next'; аргумент value сообщает Django, куда перенаправить пользователя после успешно выполненного входа. В нашем случае пользователь возвращается обратно на домашнюю страницу.