【问题标题】:Django user authentication with case insensitive username使用不区分大小写的用户名的 Django 用户身份验证
【发布时间】:2022-01-14 16:26:55
【问题描述】:

我正在完成我在 Django 中的第一个项目,当我需要查找有关我无法解决的问题的文档时,我仍然在苦苦挣扎,然后我想在这里发布一个问题。在我的 django 项目中,我安装了应用程序“users”进行身份验证,我在文件夹“users”中有以下views.py:

from django.shortcuts import render, redirect
from django.contrib.auth import login
from django.contrib.auth.forms import UserCreationForm


    def register(request):
        """Register a new user:"""
        if request.method != 'POST':
            # Display blank reigistration form.
            form = UserCreationForm()
        else:
            # Process completed form.
            form = UserCreationForm(data=request.POST)
            
            if form.is_valid():
                new_user = form.save()
                # Log the user in and then redirect to home page.
                login(request, new_user)
                return redirect('learning_journals:index')
    
    
        # Display a blank or invalid form
        context = {'form':form}
        return render(request, 'registration/register.html', context)

Models.py 目前是空的。一切都很完美,一切运作良好,无论是表单还是后端。用户可以毫无问题地访问。

当用户登录时,必须使用区分大小写的用户名。我希望用户能够使用不区分大小写的用户名登录,但我不知道如何开始并使这成为可能。

非常感谢您的帮助。如果您想了解有关我的项目的更多信息,请告诉我。

python -m django --version ---> 3.2.9

再见!

【问题讨论】:

    标签: python django django-authentication django-users


    【解决方案1】:

    您应该制作一个自定义身份验证后端,您可以这样做:

    # app_name/backends.py
    
    from django.contrib.auth import get_user_model
    from django.contrib.auth.backends import ModelBackend
    
    UserModel = get_user_model()
    
    class CaseInsensitiveModelBackend(ModelBackend):
        
        def authenticate(self, request, username=None, password=None, **kwargs):
            if username is None:
                username = kwargs.get(UserModel.USERNAME_FIELD)
            if username is None or password is None:
                return
            try:
                user = UserModel._default_manager.get(username__iexact=username)
            except UserModel.DoesNotExist:
                UserModel().set_password(password)
                return
            if user.check_password(password) and self.user_can_authenticate(user):
                return user

    然后您将AUTHENTICATION_BACKENDS setting [Django-doc] 指定为:

    # settings.py
    
    # …
    
    AUTHENTICATION_BACKENDS = ['app_name.backends.CaseInsensitiveModelBackend']
    
    # …

    【讨论】:

    • 谢谢你,Willem,你真的帮了我很多。只是回顾一下以避免错误。我需要在“用户”文件夹中创建一个新文件 backends.py,然后将该代码添加到文件中。然后在 settings.py 中添加变量 AUTHENTICATION_BACKENDS,重新启动服务器,用户现在可以使用不区分大小写的用户名和区分大小写的密码登录。对吗?
    • @Renato:您不能使用不区分大小写的密码。为此,您需要将tolower() 用于UserCreationForm,并在CaseInsensitiveModelBackendauthenticate 方法中进行修改,特别是因为密码是经过哈希处理的。
    • Willem 实际上我写了“区分大小写的密码”只是为了准确:)。总结正确吗?
    • @Renato:啊,是的,应该可以。您需要在其中一个应用程序中创建backends.py 文件(哪个应用程序并不重要,但如果您有一个用于注册和身份验证,那是最有意义的)。然后当然你在设置中将app_name替换为应用程序的名称。
    • 代码有问题:未定义“UserModel”PylancereportUndefinedVariable 第二个错误在最后一个 elif 上:Expected expressionPylance 然后在最后一个返回它只是说:Unexpected indentationPylance
    猜你喜欢
    • 2020-08-09
    • 2012-10-22
    • 2021-11-03
    • 1970-01-01
    • 1970-01-01
    • 2020-10-19
    • 2016-04-07
    • 2023-03-25
    • 1970-01-01
    相关资源
    最近更新 更多