密码重置功能 Django-Registration-Redux 应用程序



我已经在我的项目中安装了 Django-Registration-Redux 应用程序,并设置了默认的一步注册后端,到目前为止它仍然有效。现在我想通过添加密码更改机制来扩展我的应用程序的功能。我可以开始寻找的任何想法或链接。

提前致谢

PD:Django-registration-redux 文档与此主题无关。

也许这些链接会很有用:

  • https://github.com/django/django/blob/master/django/contrib/auth/urls.py
  • https://github.com/django/django/blob/master/django/contrib/auth/views.py
  • https://github.com/django/django/tree/master/django/contrib/admin/templates/registration

django-registration-redux也支持密码更改功能。对于密码更改,网址为http://your-port-number/accounts/password/change 。在您的本地主机中输入 http://your-port-address/accounts/ ,您将在屏幕上获得有关 url 映射的所有信息。使用这些 url 映射,您可以编写特定的 html 模板并直接在应用中使用它们。注册模板可在此处找到希望这有帮助。

Leif Azzopardi 和 David Maxwell《Tango With Django》一书在第 11 章中使用了"Django-Registration-Redux app",这是一个很好的例子。本章详细解释了安装/设置此模块并以清晰简洁的方式配置设置,视图和URL模式的过程。

根据这本书,模块"Django-Registration-Redux"没有为其公开的URL提供模板。您需要手动创建这些模板 - 因为这些模板往往是特定于应用程序的(应在项目的模板目录中创建名为 registration 的目录来存储这些模板文件。您还应该看到Anders Hofstee的模板,以获取一些提示来构建自己的模板。我的如下(基于他的模板(

# <my_django_project_directory>/templates/accounts/password_change_form.html
{% extends "<my_app_name>/base.html" %}
{% block body_block %}
  <h1>Change your password</h1>
  <form method="post" action=".">
    {% csrf_token %}
    {{ form.as_p }}
    <input type="submit" value="Submit" />
  </form>
{% endblock %}

假设您已在项目的settings.py中配置了模块,您应该在项目的urls.py文件中找到的url_patterns列表中包含以下 url-

url(r'^accounts/', include('registration.backends.simple.urls')),

如前面的答案所述,更改登录用户密码的 url http://<projects_root_url>/accounts/password/change .您应该通过更新菜单项将此 URL 提供给登录用户以进行访问。继续本书的示例,我更新了我的基本模板以公开密码更改网址。请考虑以下代码:

# <my_django_project_directory>/templates/<my_app_name>/base.html
{% if user.is_authenticated %}
    <li><a href="{% url 'auth_logout' %}?next=/rango/">Logout</a></li>
    <li><a href="/accounts/password/change/">Change Password</a></li>
{% else %}
    <li><a href="{% url 'auth_login' %}">Login</a></li>
    <li><a href="{% url 'registration_register' %}">Sign Up</a></li>
{% endif %}

我希望这有帮助!如果没有,那么我强烈建议您阅读上面提到的书!简单的示例,简单易懂的说明,最重要的是,该示例无需在任何配置中投入太多精力即可工作。

注意:书籍示例基于 django 版本 1.9 。我的操作系统是 Ubuntu 16.04 和 python 版本 - 3.5.2 .我的存储库包含书中的工作示例。

您可以使用

标准django.contrib.auth模板标签,并将auth_添加到标签的开头。 以下是在 Django-Registration-Redux 中如何设置auth_urls.py

from django.conf.urls import url
from django.contrib.auth import views as auth_views
from django.urls import reverse_lazy
urlpatterns = [
    url(r'^login/$',
        auth_views.LoginView.as_view(
            template_name='registration/login.html'),
        name='auth_login'),
    url(r'^logout/$',
        auth_views.LogoutView.as_view(
            template_name='registration/logout.html'),
        name='auth_logout'),
    url(r'^password/change/$',
        auth_views.PasswordChangeView.as_view(
            success_url=reverse_lazy('auth_password_change_done')),
        name='auth_password_change'),
    url(r'^password/change/done/$',
        auth_views.PasswordChangeDoneView.as_view(),
        name='auth_password_change_done'),
    url(r'^password/reset/$',
        auth_views.PasswordResetView.as_view(
            success_url=reverse_lazy('auth_password_reset_done')),
        name='auth_password_reset'),
    url(r'^password/reset/complete/$',
        auth_views.PasswordResetCompleteView.as_view(),
        name='auth_password_reset_complete'),
    url(r'^password/reset/done/$',
        auth_views.PasswordResetDoneView.as_view(),
        name='auth_password_reset_done'),
    url(r'^password/reset/confirm/(?P<uidb64>[0-9A-Za-z_-]+)/(?P<token>.+)/$',
        auth_views.PasswordResetConfirmView.as_view(
            success_url=reverse_lazy('auth_password_reset_complete')),
        name='auth_password_reset_confirm'),
]

最新更新