Django默认认证系统对is_active的验证

Django在使用默认的认证系统进行登录校验的时候authenticate函数会连同数据库里面的is_active一起验证,这样的我们这么写的代码就会有问题

user=authenticate(username=username,password=password)
        if user:
            if user.is_active:
                login(request,user)
                return redirect(reverse('goods:index'))
            else:
                return render(request,"login.html",{"errmsg":"用户未激活"})
        else:
            return render(request,"login.html",{"errmsg":"用户名或者密码错误"})

if user.is_active:段代码任何情况下都不会被执行
解决方法
在 settings.py 文件里加上下面的配置就行
不会检测用户的活跃状态
AUTHENTICATION_BACKENDS = [‘django.contrib.auth.backends.AllowAllUsersModelBackend’]

你可能感兴趣的:(python)