ModelSerializer的功能
-
创建user/serializer.py写序列化器
from rest_framework import serializer
from user.models import User
def address_validate(data):
#独立校验器
#raise serializer.ValidationError('请填写实际地址') #有错就抛出异常
#没错就返回数据
return data
class UserSerializer(serializers.ModelSerializer):
# 1.独立校验器:重新设定字段,替换掉模型中的设定,重新设定地址的长度为5
address = serializers.CharField(max_length=255, min_length=5, validators=[address_validate])
# 2.单一字段验证,验证地址
def validate_address(self.data):
if data == '测试'
raise serializers.ValidationError('请填写实际地址')
return data
def validate_phone(self, data):
# 不符合手机格式
# raise serializers.ValidationError('手机号格式不正确')
model = self.root.Meta.model
num = model.objects.filter(phone=data).count()
if num > 0:
raise serializers.ValidationError('手机号已存在')
return data
def validate(self, attrs):
# attrs:{"username":"zhangsan", "phone":"12312312311", .....}
# 所有属性验证器
# self.context 中有request和view上下文
# self.context['view'].action 可以取到动作
# attrs 是需要序列化的数据
# raise serializers.ValidationError('xxx错误') # 有问题报错
return attrs
class Meta:
model = User
fields = '__all__' #所有字段
# exclude = ['id'] #排除id字段
read_only_fields = ('', ) #指定字段为read_only,
# 扩展address: extra_kwargs = {} # 局部替换某些字段的设定,或者新增设定
extra_kwargs = {
'address': {
"min_length": 5, #给地址增加最小长度限制
"default": "默认测试地址" # 增加默认值
}
}
class UserUnActiveSerializer(serializers.ModelSerializer):
class Meta:
model = User
fields = ('id', 'username', 'is_active') # 临时添加字段也需要写在这里
#fields = "__all__"