如何解决在Django中使用哈希密码无法登录
我正在尝试实现自定义用户模型。每当我尝试登录用户时(使用注册表创建),都不会返回任何用户。 但是如果我使用管理面板创建用户,则登录功能可以正常运行。
我认为问题在于密码哈希。从这里到那里尝试了一些解决方案,但似乎找不到我想要的东西。
我遇到的问题: 电子邮件:yeamin21@outlook.com 通过:1234件作品(使用管理面板创建) 但是,电子邮件:yeamin21@outlook.com 通过:hashed(1234)不(使用注册表创建)
models.py
from django.contrib.auth.base_user import AbstractBaseUser
from django.db import models
class User(AbstractBaseUser):
username = models.CharField(max_length=30,unique=True)
email = models.EmailField(verbose_name='Email',unique=True)
name = models.CharField(max_length=100)
is_active = models.BooleanField(default=False)
is_admin = models.BooleanField(default=False)
is_customer = models.BooleanField(default=False)
is_restaurant = models.BooleanField(default=False)
date_joined = models.DateTimeField(auto_Now_add=True)
USERNAME_FIELD = 'email'
def __str__(self):
return self.name
class Restaurant(models.Model):
user = models.OnetoOneField(User,on_delete=models.CASCADE)
location = models.CharField(max_length=200)
def __str__(self):
return self.user.email
forms.py
from django.contrib.auth.forms import UserCreationForm
from django.db import transaction
from Customer.models import User,Restaurant
class RestaurantSignUpForm(UserCreationForm):
class Meta(UserCreationForm):
model = User
fields = ['email','name','username']
@transaction.atomic
def save(self,commit=True):
user = super().save(commit=False)
user.is_restaurant=True
user.is_active=True
user.save()
restaurant = Restaurant.objects.create(user=user)
restaurant.save()
return user
backend.py
from django.contrib.auth.backends import BaseBackend,ModelBackend
from Customer.models import User
class CustomBackend(ModelBackend):
def authenticate(self,email=None,password=None):
try:
user=User.objects.get(email=email)
print('active')
if user.check_password(password) is True:
return user
except User.DoesNotExist:
return None
return User.objects.get(email=User.email)
def get_user(self,email):
try:
return User.objects.get(email)
except User.DoesNotExist:
return None
views.py
from django.contrib.auth import login,authenticate
from django.http import HttpResponse
from django.shortcuts import render
from django.views import generic
from Customer.forms import RestaurantSignUpForm
from Customer.models import User
def login_page(request):
if request.method == 'POST':
email = request.POST['email']
password = request.POST['password']
user = authenticate(request,email=email,password=password)
print(user)
if user is not None:
login(request,user)
return HttpResponse("Logged in")
else:
print(user)
context = {}
return render(request,'login.html',context)
解决方法
问题已解决
感谢这个https://stackoverflow.com/a/48971226/10602634
def authenticate(self,request,email=None,password=None):
try:
user= User.objects.get(email=email)
if check_password(password,user.password):
return user
except User.DoesNotExist:
return None
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。