Ошибка пароля при настройке аутентификации Django - PullRequest
0 голосов
/ 08 мая 2019

Я пытаюсь настроить аутентификацию, которая идет по умолчанию в Django с уже созданной таблицей Mysql (соавторы). Когда я хочу зарегистрировать пользователя (с помощью command python manage.py createsuperuser), я получаю следующую ошибку:

django.db.utils.OperationalError: (1054, "Unknown column 'collaborators.password' in 'field list'").

Эта ошибка говорит о том, что столбец пароля не существует, и, действительно, у меня его нет в таблице, есть ли способ указать, что пароль получен из столбца с именем contrasena_general? Я прилагаю свой код.

models.py

class MyUserManager(BaseUserManager):
    use_in_migrations = True

    def create_superuser(self, no_colaborador, nombres_colaborador, apellido_paterno_colaborador, apellido_materno_colaborador,
                        id_plantel, id_area_colaborador, no_empleado_sup, contrasena_general, empleado_interno):

        user = self.model(no_colaborador = no_colaborador, nombres_colaborador = nombres_colaborador, 
            apellido_paterno_colaborador = apellido_paterno_colaborador, apellido_materno_colaborador = apellido_materno_colaborador,
            id_plantel = id_plantel, id_area_colaborador = id_area_colaborador, no_empleado_sup = no_empleado_sup, 
            contrasena_general = contrasena_general, empleado_interno = empleado_interno,)
        user.set_password(contrasena_general)
        user.save(using=self._db)
        return user

class Colaboradores(AbstractBaseUser):
    no_colaborador = models.IntegerField(primary_key=True)
    nombres_colaborador = models.CharField(max_length=150)
    apellido_paterno_colaborador = models.CharField(max_length=150)
    apellido_materno_colaborador = models.CharField(max_length=150)
    id_plantel = models.IntegerField()
    id_area_colaborador = models.IntegerField()
    id_centro_costos = models.IntegerField()
    no_empleado_sup = models.IntegerField()
    contrasena_general = models.CharField(max_length=100)
    empleado_interno = models.CharField(max_length=10)

    objects = MyUserManager()

    USERNAME_FIELD = "no_colaborador"

    class Meta:
        managed = False
        db_table = 'collaborators'
        app_label = "journal"

    def __str__ (self): 
        return self.email 

    def def_full_name (self): 
        return self.nombres_colaborador

    def has_perm(self, perm, obj=None):
        return self.no_colaborador

    def has_module_perms(self, app_label):
        return self.no_colaborador
# backends.py

class MyAuthBackend(object):
    def authenticate(self, no_colaborador, contrasena_general):    
        try:
            user = Colaboradores.objects.get(no_colaborador=no_colaborador)
            if user.check_password(contrasena_general):
                return user
            else:
                return None
        except Colaboradores.DoesNotExist:
            logging.getLogger("error_logger").error("user with login %s does not exists " % login)
            return None
        except Exception as e:
            logging.getLogger("error_logger").error(repr(e))
            return None

    def get_user(self, no_colaborador):
        try:
            user = Colaboradores.objects.get(no_colaborador=no_colaborador)
            if user.is_active:
                return user
            return None
        except Colaboradores.DoesNotExist:
            logging.getLogger("error_logger").error("user with %(no_colaborador)d not found")
            return None
# setting.py
...
AUTH_USER_MODEL = 'journal.Colaboradores'
AUTHENTICATION_BACKENDS = ('clientes.backends.MyAuthBackend', 'django.contrib.auth.backends.ModelBackend',)

Как вы можете указать, что пароль получен из столбца в таблице, который не называется паролем?

1 Ответ

0 голосов
/ 08 мая 2019

Я думаю, что создание вашей собственной команды createsuperuser решит эту проблему.

Ссылка: Можно ли создать собственную команду createuperuser в django?

Выможет сделать ваш код на основе исходного исходного кода для createuperuser Django , который можно найти на Github.

Как вы можете видеть оттуда, в строке 20 есть константа, которая говорит:

PASSWORD_FIELD = 'password'

Итак, я полагаю, что поскольку вы изменили его в модели на contrasena_general, вам нужно создать собственную команду.

...