Django的用户认证组件
Django的用户认证组件
用户认证
auth模块
来自django.contrib import auth
django.contrib.auth中提供了很多方法,这里我们主要介绍其中的三种:
1.1 、authenticate()
提供用户身份验证,即验证用户名和密码是否正确,一般需要用户名和密码两个关键字参数。
如果身份验证信息有效,将返回一个用户对象。Authenticate()在User对象上设置一个属性,以标识哪个身份验证后端对用户进行了身份验证,并且在以后的登录过程中需要该信息。当我们试图登录一个未经身份验证就直接从数据库中取出的用户对象()时,我们将报告一个错误!
用户=验证(用户名='某人',密码='somepassword ')
1.2 、login(HttpRequest, user)
该函数接受一个HttpRequest对象和一个经过身份验证的用户对象。
该函数使用django的会话框架将会话id等信息附加到经过身份验证的用户。
从django.contrib.auth导入authenticate,登录
def my_view(请求):
用户名=请求。开机自检['用户名']
密码=请求。开机自检['密码']
用户=验证(用户名=用户名,密码=密码)
如果用户不是非:
登录(请求、用户)
#重定向至成功页面。
.
else:
#返回“无效登录”错误消息。
.
1.3 、logout(request) 注销用户
来自django.contrib.auth导入注销
def注销_查看(请求):
注销(请求)
#重定向至成功页面。
该函数接受一个没有返回值的HttpRequest对象。调用此函数时,当前请求的所有会话信息都将被清除。即使用户没有登录,使用此功能也不会报告错误。
User对象
用户属性:用户名、密码(必需)密码通过哈希算法保存到数据库。
2.1 、user对象的 is_authenticated()
如果它是一个真实的用户对象,返回值总是真。用于检查用户是否通过身份验证。通过身份验证并不意味着用户拥有任何权限,甚至不会检查用户是否处于活动状态。这只是意味着用户已经成功通过了身份验证。这个方法很重要。在后台,使用request.user.is_authenticated()判断用户是否已经登录。如果为真,可以向前台显示request.user.name。
要求:
1用户登录后只能访问部分页面,
如果用户没有登录就访问这个页面,直接跳转到登录页面。
3.用户在跳转的登录界面完成登录后,自动访问跳转到之前访问过的地址。
方法1:
def my_view(请求):
如果没有请求,user.is_authenticated():
返回重定向(' %snext=%s' %(设置。LOGIN_URL,request.path))
方法2:
django已经为我们设计好了一个用于此种情况的装饰器:login_requierd()
来自django.contrib.auth.deco
rators import login_required
@login_required
def my_view(request):
...
若用户没有登录,则会跳转到django默认的 登录URL '/accounts/login/ ' (这个值可以在settings文件中通过LOGIN_URL进行修改)。并传递 当前访问url的绝对路径 (登陆成功后,会重定向到该路径)。
2.2 、创建用户
使用 create_user 辅助函数创建用户:
from django.contrib.auth.models import User user = User.objects.create_user(username='',password='',email='')
2.3 、check_password(passwd)
用户需要修改密码的时候 首先要让他输入原来的密码 ,如果给定的字符串通过了密码检查,返回 True
2.4 、修改密码
使用 set_password() 来修改密码
user = User.objects.get(username='') user.set_password(password='') user.save
2.5 、简单示例
注册:
def sign_up(request): state = None if request.method == 'POST': password = request.POST.get('password', '') repeat_password = request.POST.get('repeat_password', '') email=request.POST.get('email', '') username = request.POST.get('username', '') if User.objects.filter(username=username): state = 'user_exist' else: new_user = User.objects.create_user(username=username, password=password,email=email) new_user.save() return redirect('/book/') content = { 'state': state, 'user': None, } return render(request, 'sign_up.html', content)
修改密码:
@login_required def set_password(request): user = request.user state = None if request.method == 'POST': old_password = request.POST.get('old_password', '') new_password = request.POST.get('new_password', '') repeat_password = request.POST.get('repeat_password', '') if user.check_password(old_password): if not new_password: state = 'empty' elif new_password != repeat_password: state = 'repeat_error' else: user.set_password(new_password) user.save() return redirect("/log_in/") else: state = 'password_error' content = { 'user': user, 'state': state, } return render(request, 'set_password.html', content)
内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/143794.html