django 自定义auth中user登陆认证以及自写认证

Posted weilaibuxiangshuo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了django 自定义auth中user登陆认证以及自写认证相关的知识,希望对你有一定的参考价值。

第一种:

重写自定义auth中user登陆认证模块,

引入MobelBackend

from django.contrib.auth.backends import ModelBackend

重写验证模块

class CustomBackend(ModelBackend):
    def authenticate(self, request, username=None, password=None, **kwargs):
        try:
            user = Hbuser.objects.get(username=username)
            if user.is_staff :
                if user.check_password(password):
                    return user
                else:
                    return None
            return user
        except Exception as e:
            return None

注意:user.is_staff 是默认是false,这样用户就不需要输入密码,直接返回None,本教程是用于用户跟项目登陆用户共用一张表,本项目不需要让用户输入密码,只输入用户名,即可登陆

在setting里最下面设定如下:

AUTHENTICATION_BACKENDS=(bao.views.CustomBackend,)

注意:AUTHENTICATION_BACKENDS,必须是一个元组或者列表

VIews.py中,可如下例子进行验证登陆,即不需要输入密码,只需要输入用户即可登陆

class Login(View):
    def post(self,request):
        username=request.POST.get(username)
        user=authenticate(username=username, password=None)
        if user.is_authenticated:
            context={
                user:user
            }
            return render(request,index.html,context)

 

第二种:

利用user.is_staff ,判断用户是否有登陆后台

不需要写重写user登陆模块


class Login(View):
def post(self,request):
username=request.POST.get(‘username‘)
# user=authenticate(username=str(username), password=None)
user=Hbuser.objects.filter(username=username).first()
if not user.is_staff:
print ‘you xiao‘
context={
‘user‘:user
}
return render(request,‘index.html‘,context)
login(request,user)
 

 












以上是关于django 自定义auth中user登陆认证以及自写认证的主要内容,如果未能解决你的问题,请参考以下文章

django中的认证(含自定义认证)与登录

django中的认证(含自定义认证)与登录

django的RBAC认证z;自定义auth_user表;认证组件权限组件源码分析;认证组件;权限组件

Django之博客系统:自定义认证

Django之auth模块(用户认证)登陆组件

python测试开发django-42.auth模块登陆认证