Django之用户认证组件
在进行用户登陆验证的时候,如果是自己写代码,就必须要先查询数据库,看用户输入的用户名是否存在于数据库中;如果用户存在于数据库中,然后再验证用户输入的密码,这样一来就要自己编写大量的代码。事实上,Django已经提供了内置的用户认证功能。
auth
模块
1 | from django.contrib import auth |
这里介绍该模块的几个方法:
authenticate
提供了用户认证,即验证用户名以及密码是否正确,一般需要username
password
两个关键字参数。
如果认证信息有效,会返回一个 User
对象。authenticate()
会在User
对象上设置一个属性标识那种认证后端认证了该用户,且该信息在后面的登录过程中是需要的。当我们试图登陆一个从数据库中直接取出来不经过authenticate()
的User
对象会报错的!!
1 | from django.contrib import auth |
如果账户密码不正确,会返回None
。
login(HttpRequest, user)
该函数接受一个HttpRequest
对象,以及一个认证了的User
对象
此函数使用django
的session
框架给某个已认证的用户附加上session id
等信息。
1 | from django.contrib import auth |
输出结果:
1 | user 张三子 <class 'django.contrib.auth.models.User'> |
本地cookie
保存了sessionid
logout(request)
注销用户,该方法清除本地cookie和服务器session;该函数接受一个HttpRequest
对象,无返回值。当调用该函数时,当前请求的session信息会全部清除。该用户即使没有登录,使用该函数也不会报错。
1 | from django.contrib import auth |
输出:
1 | user 张三子 <class 'django.contrib.auth.models.User'> |
User
对象
User
对象属性:username
, password
(必填项)password
用哈希算法保存到数据库
is_authenticated()
如果是真正的 User 对象,返回值恒为 True 。 用于检查用户是否已经通过了认证。
通过认证并不意味着用户拥有任何权限,甚至也不检查该用户是否处于激活状态,这只是表明用户成功的通过了认证。 这个方法很重要, 在后台用request.user.is_authenticated()
判断用户是否已经登录,如果true
则可以向前台展示request.user.name
要求:
1 用户登陆后才能访问某些页面,
2 如果用户没有登录就访问该页面的话直接跳到登录页面
3 用户在跳转的登陆界面中完成登陆后,自动访问跳转到之前访问的地址
方法1:
1 | from django.contrib import auth |
方法二:
django
已经为我们设计好了一个用于此种情况的装饰器:login_requierd()
,未登录自动302跳转到登录页面。
1 | from django.contrib import auth |
创建用户
1 | from django.contrib.auth.models import User |
输出:
1 | bbb <class 'django.contrib.auth.models.User'> |
重复创建会报错:
1 | django.db.utils.IntegrityError: (1062, "Duplicate entry 'bbb' for key 'username'") |
check_password
用户需要修改密码的时候 首先要让他输入原来的密码 ,如果给定的字符串通过了密码检查,返回 True
1 | from django.contrib import auth |
输出:
1 | user 张三子 <class 'django.contrib.auth.models.User'> |
修改密码
使用 set_password() 来修改密码
1 | from django.contrib.auth.models import User |