Django 学习笔记 - 用户体系

2017-01-04  本文已影响0人  yipliksun

用户体系一————登录注册认证

cookie 和 session

Django 提供的默认实现

1. 一个数据模型 User

from dajango.contrib.auth.models import User

2. 一堆默认实现的控制器和URL

url('^accounts/', include('django.contrib.auth.urls'))
# django.contrib.auth.urls 包含如下url
^login/$[name='login']   # accounts/login/
^logout/$[name='logout']  # accounts/logout/

"django.contrib.auth.views.logout_then_login"
# 只提供了控制器,没有提供url

3. 模板全部需要自己写

流程总览

用户访问 |---------------| 激活邮件 |--------------|
-----------> | 注册页面 | ----------> | 邮箱 |
|---------------| |--------------|
| |
跳转成功 | 点击链接 |
v v
|---------------| |--------------|
| 登录页面 | | 激活接口 |
|---------------| |--------------|
registration/login.html
|
| LOGIN_REDIRECT_URL="/"
v 跳转主页

注册页面

  1. GET 展示页面
  2. POST 处理数据,创建用户,设置未激活状态。(默认是激活的,重新设置后要save()
    User.ojects.create_user(username=username, email=email, password=password)
  3. 生成随机码,发送激活邮件。
    uuid.uuid4()
  4. 激活接口。

激活链接

activate_link = "http://%s%s" % (request.get_host()), reverse("usercenter_activate", args=[new_code]))

Django 发送邮件

添加配置

EMAIL_HOST = "smtp.qq.com"
EMAIL_POST = 25  # 基本上是25
EMAIL_HOST_USER = "xxx@qq.com"
EMAIL_HOST_PASSWORD = "xxxxxx"

发送邮件

from django.core.mail import send_mail

send_mail(u'标题', u'内容', 'xxx@qq.com', [email], fail_silently=False)

写代码的良好习惯

文件命名,避免小应用重名。
block_list article_list article_create article_detail
app_xxxxx制造一个命名空间

登录页面

认证之后的用法

1. 强制认证

@login_required  (装饰器)
LOGIN_URL

2. 控制器获取用户

request.user  # 当期已登录的用户

3. 模板分权限处理

{% if user.is_authenticated %}
    <p>{{ user.username }}. 欢迎来到论坛.</p>
    <a href="{% url 'logout_then_login' %}">登出</a>
{% else %}
    <p>匿名用户. 请<a href="{% url 'login' %}">登录</a>.</p>
{% endif %}

注意

在 /usercenter/views.py 中

def activate(request, code):
    query = ActivateCode.objects.filter(code=code, expire_timestamp__gte=datetime.datetime.now())

用户体系二:密码重置 和 修改密码

        +-----------------+                    +-------------------+
        |  GET: 重置页面  |                    |                   |

----------> | POST:输入邮箱 | -----------------> | 提示发送邮件成功 |
| reset | | done |
+-----------------+ +-------------------+
|
v
+-----------------+
| 邮 箱 |
+-----------------+
|
V
+-----------------+ +------------+
| 实际重置密码 | | |
| 输入新密码 | -----------------> | 提示成功 |
| 确认新密码 | | complete |
| confirm | +------------|
+-----------------+

上一篇下一篇

猜你喜欢

热点阅读