user = User.objects.create_user(username, email, password)
user = authenticate(username=username, password=password)
正常情况下通过django自带的用户创建函数create_user进行用户创建,可将用户密码进行加密,再用authenticate函数就可以对用户名和密码进行校验
但在这次测试中,发现按如上操作user返回值一直为None,说明在表中无相应数据,多次确认操作和代码无误的情况下,百度相同情况得出的结论是django版本问题,在某些版本下会导致authenticate函数无效,但是本人之前也是在1.11.7的版本下进行操作的,也得到了正确的返回值,虽然这个结论不一定正确,对我来说没有很大的信服力,但是那位博主在网上提供了在authenticate函数无效情况下的解决方案,亲测有效,分享给大家
导入check_password函数可将明文密码和加密后的密码进行校验
from django.contrib.auth.hashers import check_password
user = User.objects.get(username=username)
pwd = user.password
# user = authenticate(username=username, password=password)
print(user)
# if user is not None:
# 第一个参数为明文密码,第二个参数为加密后的密码
if check_password(password, pwd):
# 用户名密码正确