ModelSerializer字段验证序列化
# -*- coding: utf-8 -*-
from rest_framework import serializers
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 serializer.ValidationError("手机号格式不正确")
model =self.root.Meta.model
num = model.object.filter(phone=data).count()
if num > 0:
raise serializers.ValidationError('手机好已存在')
return data
# 3. 所以属性验证器
def validate(self,attrs):
# attrs:{“user”:“zhangsan”,"phone":"17563734847",...}
# 所有属性验证器
# self.context中有request和view上下午
# attrs 是需要序列化的数据
# raise serializer.ValidationsError('xxx.错误') # 有问题报错
return attrs # 没问题返回数据
class Meta:
model = User
# fields = ('id') # 临时添加字段也需要写在这里
fields = '__all__' # 所有字段
# exclude = ['id'] # 排除id字段
read_only_fields = ('',) # 指定字段为 read_only,
# 扩展address:extra_kwargs = {} # 局部替换某些字段,或者新增设定
extra_kwargs = {
'address':{
'min_length' :5 ,# 给地址增加最小长度限制
'default' :'默认测试地址', # 增加默认值
}
}