0

私はDjango1.5を使用しています。私のユーザーモデルは次のとおりです。

class User(AbstractBaseUser):
    #id = models.IntegerField(primary_key=True)
    #identifier = models.CharField(max_length=40, unique=True, db_index=True)
    username = models.CharField(max_length=90, unique=True, db_index=True)
    create_time = models.DateTimeField(null=True, blank=True)
    update_time = models.DateTimeField(null=True, blank=True)
    email = models.CharField(max_length=225)
    #password = models.CharField(max_length=120)
    external = models.IntegerField(null=True, blank=True)
    deleted = models.IntegerField(null=True, blank=True)
    purged = models.IntegerField(null=True, blank=True)
    form_values_id = models.IntegerField(null=True, blank=True)
    disk_usage = models.DecimalField(null=True, max_digits=16, decimal_places=0, blank=True)
    #last_login = models.DateTimeField()

    objects = UserManager()
    USERNAME_FIELD = 'username'
    class Meta:
        db_table = u'galaxy_user'

正しいユーザー名とパスワードで認証できません。私のログイン機能は次のとおりです。

def login_backend(request):
    if request.method == 'POST':
        username = request.POST['username']
        password = request.POST['password']
        user = authenticate(username=username, password=password)
        if user is not None:
            login(request, user)
            return HttpResponseRedirect('/overview/')
        else:
            return HttpResponseRedirect('/login_backend/')
    else:
        return render_to_response('login_backend.html', context_instance=RequestContext(request))

私は何が間違っているのですか?

4

2 に答える 2

0

settings.pyでユーザーモデルを構成しましたか?

AUTH_USER_MODEL = 'myapp.User'

すでにsyncdbを実行している場合は、データベースを削除して再度実行する必要があります。参照:https ://docs.djangoproject.com/en/1.5/topics/auth/customizing/#substituting-a-custom-user-model

于 2013-02-12T10:37:39.560 に答える
0

最初にユーザーモデルを更新します。パスワードはありません。あなたのメールフィールドはcharfieldではありません私はそれがEmailFieldであり、あなたのパスワードもcharfieldではないと思います。正しいフィールドを検索してください。パスワードはハッシュである必要があります...

backend.py

from django.conf import settings
from app_name.models import User

class AuthBackend:
    def authenticate(self, username=None, password=None):
        if '@' in username:
            kwargs = {'email': username}
        else:
            kwargs = {'username': username}
        try:
            user = User.objects.get(**kwargs)
            if user.check_password(password):
                return user
        except User.DoesNotExist:
            return None

    def get_user(self, user_id):
        try:
            return User.objects.get(pk=user_id)
        except User.DoesNotExist:
            return None

モデルを介して「check_password」関数を作成します。このチェックの方法では、入力パスワードは、データベースに保存されているパスワードと比較する前にハッシュである必要があります。

settings.pyを更新します

AUTHENTICATION_BACKENDS = (
    'app_name.backend.AuthBackend',
    'django.contrib.auth.backends.ModelBackend',
)
于 2013-02-14T12:14:33.860 に答える