微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在Django中使用哈希密码无法登录

如何解决在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 举报,一经查实,本站将立刻删除。