class User(AbstractBaseUser): # 生成uuid id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False) #19位纯数字的Uid uid = models.CharField(max_length=19, unique=True) #RSA PublicKey public_key = models.CharField(max_length=4096, unique=True, default="") username = models.CharField(max_length=50, unique=True) password = models.CharField(max_length=255) email = models.EmailField(max_length=255, unique=True) phone = models.CharField(max_length=11, blank=True) signature = models.CharField(max_length=255, blank=True) avatar = models.ImageField(upload_to='avatars/', blank=True) status = models.IntegerField(default=0) # 0: normal, 1: banned, 2: deleted is_active = models.BooleanField(default=True) is_staff = models.BooleanField(default=False) is_superuser = models.BooleanField(default=False) USERNAME_FIELD = 'username' REQUIRED_FIELDS = ['email'] class Meta: # 配置数据库表名,及设置模型在admin站点显示的中文名 db_table = 'user_user' verbose_name = '用户' verbose_name_plural = verbose_name 执行python manage.py createsuperuser 报错in _validate_username self.UserModel._default_manager.db_manager(database).get_by_natural_key( AttributeError: 'Manager' object has no attribute 'get_by_natural_key'
时间: 2024-04-14 12:27:57 浏览: 157
深入分析mysql为什么不推荐使用uuid或者雪花id作为主键
这错误通常是由于在自定义用户模型中缺少 `get_by_natural_key` 方法引起的。`get_by_natural_key` 方法是在 `AbstractBaseUser` 类中定义的,用于通过指定字段获取用户实例。
你可以尝试在你的 `User` 模型中添加 `get_by_natural_key` 方法,示例如下:
```python
class User(AbstractBaseUser):
# ... 其他字段
# 获取用户实例
@classmethod
def get_by_natural_key(cls, username):
return cls.objects.get(username=username)
```
添加完该方法后,再次运行 `python manage.py createsuperuser` 命令,应该就不会再出现该错误了。
另外,你还需要确保你的自定义用户模型正确地继承了 `AbstractBaseUser` 类,并且在设置中正确配置了 `AUTH_USER_MODEL`。
阅读全文