无名 发表于 2022-5-8 17:03:28

【LSP】ModelSerializer自定义验证逻辑


http://cdn.u1.huluxia.com/g4/M01/60/5F/rBAAdl9ycJqATpLSAACt4WdlvYs913.jpg
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=)

#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:
            raiseserializers.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' :'默认测试地址', # 增加默认值
          }
      }http://cdn.u1.huluxia.com/g4/M01/60/5F/rBAAdl9ycJuADap9AAFndc7f15I087.jpg
页: [1]
查看完整版本: 【LSP】ModelSerializer自定义验证逻辑