AUTH_USER_MODEL относится к модели.., которая не была установлена ​​и создана. Модели AbstractUser не могут войти в систему - программирование
Подтвердить что ты не робот

AUTH_USER_MODEL относится к модели.., которая не была установлена ​​и создана. Модели AbstractUser не могут войти в систему

AUTH_USER_MODEL ошибка решена в EDIT3. Пароли по-прежнему не будут сохраняться при создании пользователя через форму.

Я использую Django 1.5, играя с новыми функциями переопределения/расширения пользователя, и я не могу регистрировать новых пользователей через мою регистрационную форму - только через Admin. При регистрации через регистрационную форму я получаю следующую ошибку:

Manager isn't available; User has been swapped for 'poker.PokerUser'

models.py:

class PokerUser(AbstractUser):
    poker_relate = models.ForeignKey(settings.AUTH_USER_MODEL, null=True, blank=True)
    token = models.EmailField()
    USER_CHOICES = (
        ('1', 'Staker'),
        ('2', 'Horse')
    )
    user_type = models.CharField(choices=USER_CHOICES, max_length=10)
    username1 = models.CharField(null=True, blank=True, max_length=40)
    username2 = models.CharField(null=True, blank=True, max_length=40)
    username3 = models.CharField(null=True, blank=True, max_length=40)
    username4 = models.CharField(null=True, blank=True, max_length=40)
    username5 = models.CharField(null=True, blank=True, max_length=40)

PokerUserForm модель:

class PokerUserForm(UserCreationForm):
    class Meta:
        model = PokerUser
        fields = ('username','password1','password2','email','user_type','token','username1','username2','username3','username4','username5',)

Я попытался изменить модель в модели PokerUserForm, чтобы использовать get_user_model() вместо явного определения модели, установив model = get_user_model() вместо model = PokerUser, но затем я получаю следующую ошибку:

django.core.exceptions.ImproperlyConfigured: AUTH_USER_MODEL refers to model 'poker.PokerUser' that has not been installed

Мой AUTH_USER_MODEL установлен в моем settings.py так:

AUTH_USER_MODEL = 'poker.PokerUser'

Вкл. - мой регистрационный просмотр в views.py:

def UserRegistration(request):
    player = PokerUser()

    if request.method == 'POST':
        form = PokerUserForm(request.POST, instance=player)
        if form.is_valid():
            player.email_address = form.cleaned_data['email']
            player.user_type = form.cleaned_data['user_type']
            # if player is staker, token is their own email. otherwise their token is their staker email and
            # their relation is their staker
            if player.user_type == '1' or player.user_type == 'staker':
                player.token = player.email_address
            else:
                player.token = form.cleaned_data['token']
                staker = PokerUser.objects.get(email=player.token)
                player.poker_relate = staker
            player.save()
            return HttpResponseRedirect('/')
    else:
        form = PokerUserForm()
    initialData = {'form': form}
    csrfContext = RequestContext(request, initialData)
    return render_to_response('registration/register.html', csrfContext)

EDIT1:

В соответствии с документами, UserCreationForm должен быть воссоздан для использования с пользовательскими классами пользователей.

Я перевернул весь UserCreationForm следующим образом:

class UserCreationForm(forms.ModelForm):
    """
    A form that creates a user, with no privileges, from the given username and
    password.
    """
    error_messages = {
        'duplicate_username': _("A user with that username already exists."),
        'password_mismatch': _("The two password fields didn't match."),
        }
    username = forms.RegexField(label=_("Username"), max_length=30,
        regex=r'^[\[email protected]+-]+$',
        help_text=_("Required. 30 characters or fewer. Letters, digits and "
                    "@/./+/-/_ only."),
        error_messages={
            'invalid': _("This value may contain only letters, numbers and "
                         "@/./+/-/_ characters.")})
    password1 = forms.CharField(label=_("Password"),
        widget=forms.PasswordInput)
    password2 = forms.CharField(label=_("Password confirmation"),
        widget=forms.PasswordInput,
        help_text=_("Enter the same password as above, for verification."))

    class Meta:
        model = PokerUser
        fields = ('username','password1','password2','email','user_type','token','username1','username2','username3','username4','username5',)

    def clean_username(self):
        # Since User.username is unique, this check is redundant,
        # but it sets a nicer error message than the ORM. See #13147.
        username = self.cleaned_data["username"]
        try:
            PokerUser.objects.get(username=username)
        except PokerUser.DoesNotExist:
            return username
        raise forms.ValidationError(self.error_messages['duplicate_username'])

    def clean_password2(self):
        password1 = self.cleaned_data.get("password1")
        password2 = self.cleaned_data.get("password2")
        if password1 and password2 and password1 != password2:
            raise forms.ValidationError(
                self.error_messages['password_mismatch'])
        return password2

    def save(self, commit=True):
        user = super(UserCreationForm, self).save(commit=False)
        user.set_password(self.cleaned_data["password1"])
        if commit:
            user.save()
        return user

И это удалось решить эту ошибку:

The Manager isn't available; User has been swapped for 'poker.PokerUser'

Теперь пользователи создаются, но не могут войти в систему. Когда я проверяю пользователей в admin, вся информация кажется правильной, за исключением пароля. Добавление пароля вручную в админ не работает корректно. Тем не менее, добавление пользователей через администратор работает правильно.

ИЗМЕНИТЬ 2:

Я все еще не могу войти в систему как любая из моих моделей AbstractUser, созданных через регистрационную форму. Я полностью переопределил UserCreationForm, как описано выше, и я не могу реализовать get_user_model() с этой ошибкой:

AUTH_USER_MODEL refers to model 'poker.PokerUser' that has not been installed

Код Django для get_user_model():

 def get_user_model():
    "Return the User model that is active in this project"
    from django.conf import settings
    from django.db.models import get_model

    try:
        app_label, model_name = settings.AUTH_USER_MODEL.split('.')
    except ValueError:
        raise ImproperlyConfigured("AUTH_USER_MODEL must be of the form 'app_label.model_name'")
    user_model = get_model(app_label, model_name)
    if user_model is None:
        raise ImproperlyConfigured("AUTH_USER_MODEL refers to model '%s' that has not been installed" % settings.AUTH_USER_MODEL)
    return user_model

Поскольку у меня есть AUTH_USER_MODEL = 'poker.PokerUser' настройка в моем settings.py, это должно работать. Я проверил это через консоль Django:

>>> from django.contrib.auth import get_user_model
>>> settings.AUTH_USER_MODEL
Out[14]: 'poker.PokerUser'
>>> from django.db.models import get_model
>>> app_label, model_name = settings.AUTH_USER_MODEL.split('.')
>>> user_model = get_model(app_label, model_name)
>>> user_model
Out[18]: poker.models.PokerUser

Однако реализация по-прежнему не работает правильно.

Если вы прочли это, спасибо!

EDIT3:

AUTH_USER_MODEL refers to model 'poker.PokerUser' that has not been installed исправлено. У меня случайно был UserCreationForm, который я воссоздал в poker.models вместо registration.forms, поэтому, когда я запускал get_user_model(), который был назначен poker.PokerUser, он не мог решить, так как он уже был в этом месте.

Теперь остается только проблема: при создании новых пользователей их пароли не будут сохраняться. Я сузил его до одного метода в UserCreationForm, разместив здесь инструкции для печати:

def clean_password2(self):
    password1 = self.cleaned_data.get("password1")
    print password1
    password2 = self.cleaned_data.get("password2")
    print password2
    if password1 and password2 and password1 != password2:
        raise forms.ValidationError(
            self.error_messages['password_mismatch'])
    print password2
    return password2

def save(self, commit=True):
    user = super(UserCreationForm, self).save(commit=False)
    user.set_password(self.cleaned_data["password1"])
    print self.cleaned_data["password1"]
    if commit:
        user.save()
    return user

Операторы print password1 и print password1 в clean_password2 отображают пароль обычного текста, но print self.cleaned_data["password1"] в методе save пуст. Почему данные формы не передаются методу сохранения?

TL; DR AbstractUser создание модели работает как в Admin, так и через регистрационную форму, но только пользователи, созданные через Admin, могут войти в систему. Пользователи, созданные через регистрационную форму, не могут войти в систему и, кажется, будут сохранены без пароля - вся другая информация будет сохранена правильно.

4b9b3361

Ответ 1

Хорошо, для меня было три проблемы, поэтому я собираюсь рассмотреть их все, так как я уверен, что первые два придут к кому-то другому.

  • Manager isn't available; User has been swapped for 'poker.PokerUser'

Это было связано с использованием, но не воссозданием UserCreationForm. При использовании пользовательских моделей в 1.5, некоторые формы моделей доступны из коробки, но этот должен быть воссоздан. См. здесь для документов.

  • The Manager isn't available; User has been swapped for 'poker.PokerUser'

Пока у меня был AUTH_USER_MODEL = 'poker.PokerUser' установлен в моем settings.py, я вызывал get_user_model() из местоположения poker.models. Вы должны позвонить get_user_model() из другого места. Перемещение моей формы на registration.forms и вызов get_user_model() оттуда работали правильно.

  • Новые пользователи не сохраняют

Это был просто мозговой пердит на моем конце. В моей модели UserRegistration я манипулировал различными полями из формы. Когда я передал эти поля обратно в UserCreationForm для метода save(), я не передавал ему поля пароля. Woops!

Ответ 2

Я сталкивался с этим несколько раз. Это всегда была проблема импорта. Предположим, у нас есть core/models.py, который реализует пользовательский пользователь и импортирует символ из другого файла (например, Else):

from Something import Else

class CustomUser(AbstractBaseUser):
    pass

И у нас есть еще один файл, который использует CustomUser, а также определяет Else. Позвольте называть это something/models.py:

from core.models import CustomUser

class Else(models.Model):
    pass

class AnotherClass(models.model):
    user = models.ForeignKey(CustomUser)

Когда core/models.py переходит на импорт Else, он оценивает что-то/models.py и запускается в определение AnotherClass. AnotherClass использует CustomUser, но CustomUser еще не установлен, потому что мы в процессе его создания. Таким образом, он выдает эту ошибку.

Я решил эту проблему, оставив свой ядро ​​/models.py автономным. Это не сильно влияет на мои другие приложения.

Ответ 3

В моем случае обновление, надлежащая app_label в мета-решении этой проблемы

class APPUser(AbstractUser):
   password = models.TextField(blank=True)

   class Meta:
     app_label = 'app_auth'
     db_table = "app_user"

Ответ 4

Это может произойти, если вы забудете зарегистрировать свое приложение в настройках. В вашем файле settings.py добавьте название вашего приложения в список INSTALLED_APPS. Надеюсь, это поможет.

Например, если имя вашего приложения "пользователи", оно будет выглядеть так:

INSTALLED_APPS = [
  ......

  'users'
]

Ответ 5

Чтобы процитировать Django docs:

Вам также потребуется зарегистрировать свою пользовательскую модель с помощью администратора. Если ваша пользовательская модель пользователя расширяется django.contrib.auth.models.AbstractUser, вы можете использовать Django existing django.contrib.auth.admin.UserAdmin.

Проверьте содержимое вашего файла admin.py и убедитесь, что вы зарегистрировали свою пользовательскую модель в системе администратора с помощью класса django.contrib.auth.admin.UserAdmin.