我自己在使用django进行登录操作的时候时,没用它自带的那个登录验证,而是自己写了一个数据库,然后代码如下:
def signin(request):
if request.method == 'POST':
userName = request.POST.get('username')
passWord = request.POST.get('password')
# 使用 Django auth 库里面的 方法校验用户名、密码
#user = authenticate(username=userName, password=passWord)
user = Volunteer1.objects.filter(name=userName,password=passWord)
# 如果能找到用户,并且密码正确
if user:
return JsonResponse({'ret': 0, 'msg': '正常用户'})
elif user.type=='1'
return JsonResponse({'ret': 0, 'msg': '高级用户'})
else:
return JsonResponse({'ret': 1, 'msg': '用户名或者密码错误'})
然后没有报错,也能正常运行。
但是跟网页上的前端一结合,就网页报错
于是我发现走到elif user.type=='1'时就报错
所以将user进行如下修改就解决报错了,在后面加一个.first()
user = Volunteer1.objects.filter(name=userName,password=passWord).first()