Django Auth用户认证组件实现代码
用户认证组件:
功能:用session记录登录验证状态
前提:用户表:django自带的auth-user
python3manage.pycreatesuperuser#创建超级用户
补充匿名用户:
API: fromdjango.contribimportauth: 1.#if验证成功返回user对象,否则返回None user=auth.authenticate(username=user,password=pwd) 2.auth.login(request,user)#request.user当前登录对象 3.auth.login(request) fromdjango.contrib.auth.modelsimportUser#User==auth_user 4.request.user.is_authenticated 5.user=User.objects.create_user(username='',password='',email='') 补充: 匿名用户对象: 匿名用户 classmodels.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。 NewinDjango1.8: 新增AnonymouseUser.get_username()以更好的模拟django.contrib.auth.moudels.User总结:ifnot:auth.login(request,user)request.user=AnonymousUser()else:request.user==登录对象request.user是一个全局变量
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。