Django-AttributeError'User'对象没有属性'backend'(但......它确实如此?)

时间:2011-05-17 17:32:11

标签: django authentication django-models django-authentication

为了在注册用户后对其进行签名,我手动设置了user.backend属性。它通常适用于我的观点。在这个例子中,我试图通过AJAX注册用户。它引发了一个AttributeError。

这是我的代码:

 def register_async(request):
    if request.method=='POST':

    userform=MyUserCreationForm(request.POST)
    if userform.is_valid():
        #username of <30 char is required by Django User model.  I'm storing username as a hash of user email 

        user=userform.save(commit=False)
        user.username=hash(user.email)
        user.backend='django.contrib.auth.backends.ModelBackend'
        user.save()


        auth.login(request,user)
        user_status=1
        user_fname=user.first_name
        user_data=[{'user_status':user_status, 'user_fname':user_fname}]
        json_data=json.dumps(user_data)
        response=HttpResponse()
        response['Content-Type']="text/javascript"
        response.write(json_data)
        return response 

    else:
        user_data=[{'user_status':"0"}]
        json_data=json.dumps(user_data)
        response=HttpResponse()
        response['Content-Type']="text/javascript"
        response.write(json_data)
        return response 
else:
    return HttpResponse()
编辑 - 这是AJAX。它看起来非常标准

     //ajax registration.  
$('input#register_submit').click(function(event){
    $(this).attr('disabled','disabled');
    $('<div class="register-animation"><img src="{{site}}media/ajax-loader3.gif"/></div>').appendTo('#register_modal_btn');

    $.post("/register/", $('div#register_side form').serialize(), 
        function(data){
            $.each(data,function(){
            if(this.user_status==1){
                $('.register-animation').remove();
                $('.right_section .top').html('<ul><li class="sep_nav">Hi, '+ this.user_fname + '</li><li class="sep+nav"><a href="http://nabshack.com/logout/">Log Out</a></li><li class="refar_friend"><a href="http://nabshack.com/referral/">Refer a friend and get $50</a></li></ul>');
                $('#post_login_modal').dialog("close");

                $('a.login').unbind('click');
                $('li a.account').unbind('click');

            }       
            else{
            $('input#register_submit').removeAttr('disabled');
            $('.register-animation').remove();
            window.location='{{site}}register';
            }

        });
    },'json');
    return false;
    event.stopPropagation();
});

对于我来说,这个确切的代码非常适用于非ajax视图。是什么给了什么?

由于

3 个答案:

答案 0 :(得分:82)

您必须先致电authenticate,然后才能致电loginauthenticate在对象上设置一个属性,指出哪个后端已成功验证它并清除它以进行登录,这在您的代码中没有发生(这是缺少的属性)。

文档:https://docs.djangoproject.com/en/1.8/topics/auth/default/#how-to-log-a-user-in - 查看“首先调用authenticate()”的小标注。

答案 1 :(得分:46)

我会将此作为答案发布,但我在上面的评论https://stackoverflow.com/users/558699/benhttps://stackoverflow.com/a/5837046/1467342中欠它。我正在扫描这个问题而错过了我在寻找的内容。到目前为止,手动添加后端对我来说是一个(hacky)修复程序两次:

user.backend = 'django.contrib.auth.backends.ModelBackend'
login(request, user)

在这两种情况下,我都依赖其他身份验证方法(电子邮件确认和管理员身份验证会话)来验证以此用户身份登录的权限。

答案 2 :(得分:0)

在Django 1.10中,django.contrib.auth.login现在采用backend=关键字参数!

https://code.djangoproject.com/ticket/24855