DJANGO的用户认证系统
- 2020 年 3 月 17 日
- 笔记
Django自带的用户认证系统,为开发者提供了许多在用户登陆登出方面的快捷开发命令。这篇博文为初学者讲解如何使用django的用户认证系统。 Django版本2.X
1.User模型
User模型是抽象的用户,对应总的用户表,可以用来配置页面的访问权限,注册用户的配置文件等功能。Djang中对应的User类只有一个,“超级管理员”(superuser)或“普通用户”(staff)是用户类的属性对象,而不是不同的类。 默认的用户的主要属性是: username,password,email,first_name,last_name等,具体的属性请参考官方文档。
2.创建用户
创建一个新的用户对象,实际上是实例化处一个User类的对象。通常你可以: 直接创建
from django.contrib.auth.models import User user = User() user.username=kevinguo user.first_name=kevin user.last_name=guo
用户的密码不能以明文的方式存储在数据表中,所以应当对密码进行加密运算set_password方法是对明文密码进行加密。
user.set_password("new password") user.save
使用create_user方法 显然,上述方法不够简便,django为我们提供了更加方便的方法直接创建一个新的用户
from django.contrib.auth.models import User new_user = User.objects.create_user('kevinguo','[email protected]','mypassword')
通过上述代码,django相当于执行了我们第一步中的包含save操作的所有内容,这个新的用户已经被保存在用户表中了,如果我们想额外增加新的字段,可以通过如下类似的操作。
user.first_name="kevin" user.last_name="guo" user.save()
3.创建超级管理员用户
为安全起见,超级管理员用户无法通过如上方法创建,django为我们提供的manage.py 工具包中的方法可以创建一个超级管理员用户
python manage.py createsuperuser --username=kevinguo [email protected]
之后,你会被提示输入两次密码,完成创建。如果你带上参数,同时也被要求输入这些。
4更改密码
在shell中更改密码
python manage.py changepassword *username*
在代码处修改,使用set_password()
user = User.objects.get(username="kevinguo") user.set_password('new password') user.save()
特别注意的是,如果用户密码更改后,该用户的所有登陆状态均失效。
5.用户验证authenticate
使用authenticate()来验证用户。它使用username和password作为参数进行验证,对每个身份验证后端(setting.py 中的 authentication backend)进行一一检查,如果有一个认证后端返回一个user对象(class:django.contrib.auth.model User),则停止向下检查。如果后端引发PermissionDenied错误,将返回None.下面在代码中进行举例说明
from django.contrib.auth import authenticate user = authenticate(username="kevinguo",password="mypassword") if user: pass else: pass
6.用户的登陆
如何将上述已经得到验证的用户添加到当前的会话(session)中?django,使用login()函数来完成。 下面的例子综合了上方的authenticate方法和login方法,完整的展示了一个简单的用户认证登陆过程。简便期间,使用视图函数处理。
from django.contrib.auth import authenticate,login def login_view(request): username = request.POST['username'] password = request.POST['password'] user = authenticate(username=username,password=password) if user: login(request,user) #返回一个登陆成功的页面 else: #返回一个错误页面
7.用户的登出logout()
如果已经通过login登录的用户想要登出,可以在视图中使用django.contrib.auth.logout(),该函数不会返回任何值。
from django.contrib.auth import logout def logout_view(request): logout(request) #返回一个登出的成功页面
你可以根据自己的需求在以上基础上添加更为复杂的业务逻辑。