如何规范化 Django REST Serializer 中的电子邮件字段值?
How to normalize email field value in Django REST Serializer?
总的来说,我是 Django 的新手,所以请不要苛刻地评判我。
我有一个自定义用户模型,我使用 DRF 创建用户配置文件。我在 create_user(BaseUserManager 的方法)中规范化电子邮件。我找不到如何在 API 序列化程序中也规范化电子邮件字段的值的方法。基本上,如果我传递的电子邮件已经存在于数据库中,但域中只有大写字母,它将通过序列化程序的验证,但是在以下之后会遇到完整性错误:
duplicate key value violates unique constraint "accounts_user_email_key"
DETAIL: Key (email)=(email@example.com) already exists.
这是我的 UserManager 方法的简化版本:
class UserManager(BaseUserManager):
def create_user(self, email, first_name, last_name, password):
#some validation logic
#...
user = self.model(
email=self.normalize_email(email),
first_name=first_name,
last_name=last_name
)
user.set_password(password)
user.save()
return user
#other stuff...
这是一个 Serializer 本身:
class UserSerializer(serializers.ModelSerializer):
class Meta:
model = models.User
fields = ('email', 'first_name', 'last_name', 'password')
extra_kwargs = {k: {'write_only': True} for k in fields}
#some password validation...
def create(self, validated_data):
user = models.User.objects.create_user(
email=validated_data['email'],
first_name=validated_data['first_name'],
last_name=validated_data['last_name'],
password=validated_data['password']
)
return user
这是视图:
class UserCreate(generics.CreateAPIView):
serializer_class = serializers.UserSerializer
您可以在序列化程序中使用 field-level-validation:
class UserSerializer(serializers.ModelSerializer):
class Meta:
model = models.User
fields = ('email', 'first_name', 'last_name', 'password')
extra_kwargs = {k: {'write_only': True} for k in fields}
def validate_email(self, value):
norm_email = value.lower()
if models.User.objects.filter(email=norm_email).exists():
raise serializers.ValidationError("Not unique email")
return norm_email
总的来说,我是 Django 的新手,所以请不要苛刻地评判我。
我有一个自定义用户模型,我使用 DRF 创建用户配置文件。我在 create_user(BaseUserManager 的方法)中规范化电子邮件。我找不到如何在 API 序列化程序中也规范化电子邮件字段的值的方法。基本上,如果我传递的电子邮件已经存在于数据库中,但域中只有大写字母,它将通过序列化程序的验证,但是在以下之后会遇到完整性错误:
duplicate key value violates unique constraint "accounts_user_email_key"
DETAIL: Key (email)=(email@example.com) already exists.
这是我的 UserManager 方法的简化版本:
class UserManager(BaseUserManager):
def create_user(self, email, first_name, last_name, password):
#some validation logic
#...
user = self.model(
email=self.normalize_email(email),
first_name=first_name,
last_name=last_name
)
user.set_password(password)
user.save()
return user
#other stuff...
这是一个 Serializer 本身:
class UserSerializer(serializers.ModelSerializer):
class Meta:
model = models.User
fields = ('email', 'first_name', 'last_name', 'password')
extra_kwargs = {k: {'write_only': True} for k in fields}
#some password validation...
def create(self, validated_data):
user = models.User.objects.create_user(
email=validated_data['email'],
first_name=validated_data['first_name'],
last_name=validated_data['last_name'],
password=validated_data['password']
)
return user
这是视图:
class UserCreate(generics.CreateAPIView):
serializer_class = serializers.UserSerializer
您可以在序列化程序中使用 field-level-validation:
class UserSerializer(serializers.ModelSerializer):
class Meta:
model = models.User
fields = ('email', 'first_name', 'last_name', 'password')
extra_kwargs = {k: {'write_only': True} for k in fields}
def validate_email(self, value):
norm_email = value.lower()
if models.User.objects.filter(email=norm_email).exists():
raise serializers.ValidationError("Not unique email")
return norm_email