Django基础之扩展内置用户模型
一:内置验证系统
1.1 auth模块
from django.contrib import auth
django.contrib.auth中提供了许多方法,这里主要介绍其中的三个
authenticate() :
提供了用户认证,即验证用户名以及密码是否正确,一般需要username password两个关键字参数
如果认证信息有效,会返回一个 User 对象。authenticate()会在User 对象上设置一个属性标识那种认证后端认证了该用户,且该信息在后面的登录过程中是需要的。当我们试图登陆一个从数据库中直接取出来不经过authenticate()的User对象会报错的!
user = authenticate(username='someone',password='somepassword')
注意:
在Django1.8版本中,authenticate方法传入username, password两个参数后是不校验is_active字段的
在Django2.0版本中,authenticate方法传入username, password两个参数后,如果is_active字段为False时,将返回None
如果想在Django2.0版本中校验 is_active 字段,可以settings配置文件中添加下面一行配置
AUTHENTICATION_BACKENDS = ['django.contrib.auth.backends.AllowAllUsersModelBackend']
login(HttpRequest, user):
该函数接受一个HttpRequest对象,以及一个认证了的User对象
此函数使用django的session框架给某个已认证的用户附加上session id等信息。
logout(request) 注销用户:
该函数接受一个HttpRequest对象,无返回值。当调用该函数时,当前请求的session信息会全部清除。该用户即使没有登录,使用该函数也不会报错。
1.2 User对象
如果是真正的 User 对象,返回值恒为 True 。 用于检查用户是否已经通过了认证。
通过认证并不意味着用户拥有任何权限,甚至也不检查该用户是否处于激活状态,这只是表明用户成功的通过了认证。 这个方法很重要, 在后台用request.user.is_authenticated判断用户是否已经登录,如果true则可以向前台展示request.user.username
login_required装饰器:
若用户没有登录,则会跳转到django默认的 登录URL '/accounts/login/ ’ (这个值可以在settings文件中通过LOGIN_URL进行修改)。并传递当前访问url的绝对路径 (登陆成功后,会重定向到该路径)。
create_user :
使用 create_user 辅助函数创建用户
from django.contrib.auth.models import User
def index(request):
user = User.objects.create_user(username = 'andy', email = 'andy@qq.com', password = '123456')
# 在默认的auth_user表中创建用户,默认is_active = 1,激活的
return HttpResponse('index page')
create_superuser:
创建后台超级用户
user = User.objects.create_superuser(username = 'rambo', email = 'rambo@qq.com', password = '123456')
# 当然也可以在命令行中创建
check_password:
用户需要修改密码的时候 首先要让他输入原来的密码 ,如果给定的字符串通过了密码检查,返回 True
set_password:
使用 set_password() 来修改密码
user = User.objects.get(username='')
user.set_password(password='')
user.save
1.3 用户认证实例
from django.shortcuts import render