繁体   English   中英

Django的身份验证方法不起作用

[英]Django authenticate method not working

我正在尝试使用django.contrib.auth authenticate()方法中的默认Django进行身份验证(如果用户存在)。 我在用户注册后立即执行此操作。 用户注册,并将他们的用户名,电子邮件和密码输入数据库,但是当我调用authenticate(username=username, password=password) ,由于某种原因它返回None 密码存储为哈希值,值得注意的是,我使用的是我自己的自定义用户模型,但该继承自django.contrib.auth用户模型。

这是我的看法:

class RegisterView(SuccessMessageMixin, View):
    form_class = RegisterForm
    template_name = 'oauth/auth_form.html'
    success_message = "You have successfully created an account!"

    # Display blank form
    def get(self, request):
        form = self.form_class(None)
        return render(request, self.template_name, {'form': form})

    def post(self, request):
        form = self.form_class(request.POST)

        if form.is_valid():
            user = form.save(commit=False) # Do not save to table yet

            username = form.cleaned_data['username']
            password = form.cleaned_data['password']

            try:
                validate_password(password, user)

            except ValidationError as e:
                form.add_error('password', e)  # to be displayed with the field's errors
                return render(request, self.template_name, {'form': form})

            user.set_password(password)
            user.save()

            # Let's try to login the user
            user = authenticate(username=username, password=password)

            if user is not None:

                login(request, user)
                return redirect('http://google.com')


        return render(request, self.template_name, {'form': form})

为什么验证方法对我不起作用?

尽管@schwobaseggl的答案可以解决您的问题,即“无需身份验证,只需直接登录”,但我在一个较旧的项目中做了非常相似的事情,也许可以为您提供帮助。

在这里,注册过程自动登录用户,并且我们使用电子邮件令牌作为密码:

def get_or_create_user(mobile):
    UserModel = get_user_model()
    try:
        user = UserModel.objects.get(mobile=mobile)
    except UserModel.DoesNotExist:
        user = UserModel(mobile=mobile, username=mobile)
        user.set_unusable_password()
        user.save()
    return user

...

class UserRegistrationAndLogin(View):
    ...

    def post(self, request):
        form = self.form_class(request.POST)
        next_url = request.GET.get('next')
        if form.is_valid():
            entered_token = form.cleaned_data['otp']
            if entered_token == self.token:
                user = get_or_create_user(mobile=self.mobile)
                login(request, user)
                return redirect(next_url or settings.LOGIN_REDIRECT_URL)
            else:
                form.add_error('otp', 'OTP does not match!')
        return render(request, self.template_name, context={'form': form, 'mobile': self.mobile})

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM