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’]