0

私の Django サイトでは、カスタム ユーザー モデルを作成しました。Windows 認証を使用しているため、これまでユーザーは直接サイトにアクセスできました。管理ページでユーザーを作成し、そこで権限を編集することもできます。Violation of UNIQUE KEY constraint 'UQ__accounts__AB6E616413786680'. Cannot insert duplicate key in object 'dbo.accounts_ouser'. The duplicate key value is ().サーバー管理スタジオを使用しても新しいユーザーを挿入することさえできないため、エラーはデータベース側にあるようです。

class OUser(AbstractBaseUser, PermissionsMixin):
    email = models.EmailField(verbose_name='email address', max_length=255, unique=True)
    username = models.CharField(max_length=150, unique=True)
    is_active = models.BooleanField(default=True)
    is_staff = models.BooleanField(default=False)
    is_superuser = models.BooleanField(default=False)  # a superuser

    first_name = models.CharField(max_length=100, blank=True, default='')
    last_name = models.CharField(max_length=100, blank=True, default='')
    date_joined = models.DateField(auto_now=True)
    password = models.CharField(max_length=100)

    REQUIRED_FIELDS = []  # Email & Password are required by default.
    USERNAME_FIELD = 'username'

    def __str__(self):
        return self.username

    def has_perm(self, perm, obj=None):
        "Does the user have a specific permission?"
        # Simplest possible answer: Yes, always
        return True

    def has_module_perms(self, app_label):
        "Does the user have permissions to view the app `app_label`?"
        # Simplest possible answer: Yes, always
        return True

もう 1 つの奇妙な点は、UNIQUE KEY 制約の使用です。列 ID は PRIMARY KEY 制約である必要があり、ouser モデルは他のキーを実装していません。(それが一般的かどうかはわかりませんが、私には奇妙に思えます)

私が望むのは、サイトが元の状態に戻り、ユーザーが Windows で認証された場合にアクセスできるようになることです。

なぜこれが考えられるのか、誰にも分かりますか?

4

1 に答える 1