这篇文章将为大家详细讲解有关Django Auth实现用户认证组件,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
用户认证组件:
功能:用session记录登录验证状态
前提:用户表:django自带的auth-user
python3 manage.py createsuperuser #创建超级用户
补充匿名用户:
API:
from django.contrib import auth :
1. #if 验证成功返回user对象,否则返回None
user = auth.authenticate(username=user,password=pwd)
2. auth.login(request,user) #request.user 当前登录对象
3. auth.login(request)
from django.contrib.auth.models import User #User == auth_user
4. request.user.is_authenticated
5.user = User.objects.create_user(username='',password='',email='')
补充:
匿名用户对象:
匿名用户
class models.AnonymousUser
django.contrib.auth.models.AnonymousUser #这个类实现了django.contrib.auth.models.User
借口,但是又几点不同:
id永远是None
username永远为空字符串
get_username()永远返回空字符串
is_staff和is_superuser永远是False
is_active永远是False
groups和user_permissions永远为空
is_annonymous()返回True 而不是False
is_authenticated()返回时False,而不是True
set_password()、check_password()、save()和delete()引发NotImplementedError。
New in Django 1.8:
新增 AnonymouseUser.get_username()以更好的模拟django.contrib.auth.moudels.User总结: if not :auth.login(request,user) request.user = AnonymousUser() else:request.user==登录对象 request.user是一个全局变量
关于Django Auth实现用户认证组件就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。