0

我知道这个答案:TypeError: get_session_auth_hash() missing 1 required positional argument: 'self',但我没有使用自定义后端,并且在通过 Django 表单注册新用户时发生了有问题的错误,而不是在登录时.

此外,虽然用户在注册时没有保持登录状态,也没有按预期自动重定向到主页,但从登录表单登录似乎可以正常运行。

错误发生在我的注册视图中的这一行:login(request, User)

并追溯到 django.contrib.auth 中的这一行:

    if user is None:
        user = request.user
    if hasattr(user, 'get_session_auth_hash'):
        session_auth_hash = user.get_session_auth_hash() <<<<<<<<< This line

我认为因为我使用的是自定义用户,所以我需要在默认代码中修改其他内容,但我不确定这应该是什么。我认为自定义用户模型应该可以与默认用户模型互换,但事实并非如此,我欢迎比我更有经验的人为我指明正确的方向。

我的代码如下:

自定义用户模型和管理器models.py

from django.contrib.auth.models import AbstractBaseUser, BaseUserManager

class UserManager(BaseUserManager):
    def create_user(self, email, password = None, active = True, staff = False, superuser = False):
        if not email:
            raise ValueError('Users must have an email')
        if not password:
            raise ValueError('Users must have a password')
        user = self.model(email = self.normalize_email(email))
        user.set_password(password)
        user.staff = staff
        user.superuser = superuser      
        user.active = active     
        user.save(using=self._db)
        return user

    def create_staffuser(self, email, password = None):
        user = self.create_user(email, password = password, staff = True)
        return user

    def create_superuser(self, email, password = None):
        user = self.create_user(email, password = password, staff = True, superuser = True)
        return user

class User(AbstractBaseUser):
    user_id         = models.AutoField(primary_key=True)
    email           = models.EmailField(max_length = 255, unique =True, default = 'abc123@domain.ext')
    active          = models.BooleanField(default = True)#can login
    staff           = models.BooleanField(default = False)#staff user non superuser
    superuser       = models.BooleanField(default = False)#superuser
    
    USERNAME_FIELD = 'email' #to set username
    #username and passwor fields are required by default
    REQUIRED_FIELDS = []

    objects = UserManager()

    def __str__(self):
        return (str(self.user_id) + ' ' + ' ' + self.email)

    def has_perm(self, perm, obj=None):
        return self.superuser

    def has_module_perms(self, app_label):
        return self.superuser

    @property
    def is_staff(self):
        return self.staff

    @property
    def is_superuser(self):
        return self.superuser
    

    @property
    def is_active(self):
        return self.active

注册视图views.py

from .models import User
from .forms import NewUserForm

def register_request(request):
    if request.method == "POST":
        form = NewUserForm(request.POST)
        if form.is_valid():
            user = form.save()
            login(request, User)
            messages.success(request, "Registration successful." )
            return redirect("main:homepage")
        messages.error(request, "Unsuccessful registration. Invalid information.")
    form = NewUserForm()
    return render (request=request, template_name="main/register.html", context={"register_form":form})

forms.py

from django.contrib.auth.forms import UserCreationForm
from .models import User

class NewUserForm(UserCreationForm):
    email = forms.EmailField(required=True)

    class Meta:
        model = User
        fields = ("email", "password1", "password2")

    def save(self, commit=True):
        user = super(NewUserForm, self).save(commit=False)
        user.email = self.cleaned_data['email']
        if commit:
            user.save()
        return user

请告诉我您是否还有其他需要看的东西。如果这里的其他地方回答了这个问题,请原谅我,但我已经看过了,而不仅仅是上面的链接!提前致谢。

注意:尝试更换

from .models import User

和:

from django.contrib.auth import get_user_model 
User = get_user_model()

在所有使用用户模型的模块中。同样的错误发生在相同的位置。

4

2 回答 2

2

你有一个错字login。您正在使用Userwhich 是类而不是user

login(request, User) # --> should be login(request, user)
于 2021-07-23T04:08:55.907 回答
2

您的代码看起来不错..也许一项更改可以解决您的问题:

更改此行

from .models import User

from django.contrib.auth import get_user_model 
User = get_user_model()
于 2021-07-21T21:41:35.063 回答