ModelSerializer字段验证、序列化

from rest_framework import serializers
from user.models import User

def address_validate(data):
    # 独立校验器
    # raise serializers.ValidationError('请写真实地址')    有错就抛出异常
    return data
    # 没错就返回数据
    return data

class UserSerializer(serializers.ModelSerializer):
    # 1.独立校验器:重新设定字段,替换掉模型中的设定,重新设定地址长度为5
    address = serializers.CharField(max_length=225, 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
    
    # 3.所有属性验证器
    def validate(self,attrs):
        #attrs:{"username":"zhangsan","phone":"185156315",....}
        # 所有属性验证器
        # self.context 中有requset和view上下文
        # self.context['view'].action 可以取到动作
        # attrs 是需要序列化的数据
        # raise serializers.ValidationError('xxx错误') # 又问题报错 
        return attrs  # 没问题返回

    
    class Meta:
        model = User
        # fields = ('id',) # 临时添加字段也要写在这里
        fields = "__all__" # 所有字段
        # exclude = ['id] # 排除 id 字段
        read_only_fields = ('',) #指定字段为 read_only


        # 扩展address:  extra_kwargs = {} # 局部替换某些字段的设定, 或者新增设定
        exrea_kwargs={
            'address':{
                'min_length':5,
                'default':'默认测试' # 增加默认值
            }
        }
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DRF(Django Rest Framework)是一种用于构建Web API的强大框架,它提供了丰富的功能和工具来简化API的开发过程。在使用DRF时,我们经常需要定义视图和序列化器以及它们之间的关系来处理不同的请求和操作。 DRF的请求处理基于视图的操作方法,它们分别对应于HTTP方法,例如GET,POST,PUT,PATCH和DELETE。这些操作方法在视图中以函数的形式定义,并且通过装饰器或路由来映射到相应的URL。 序列化器是DRF的一个核心概念,它提供了一种简单而灵活的方式,将数据对象转换为可以被序列化和反序列化的格式,通常是JSON或XML。序列化器可以定义在视图中,也可以单独定义为一个类,然后在视图中使用。 在DRF中,我们可以通过定义不同的序列化器类来处理不同的操作。序列化器类可以继承自DRF提供的Serializer类或ModelSerializer类,后者自动为我们根据模型生成序列化字段。 使用序列化器,我们可以在视图中方便地对请求进行验证、数据转换和结果序列化等操作。在视图的操作方法中,我们可以通过调用序列化器的不同方法来进行这些操作。 例如,我们可以使用序列化器的`is_valid()`方法来验证请求的数据是否有效。我们还可以使用`save()`方法来保存数据,或者使用`data`属性来获取序列化后的数据。此外,我们还可以通过调用`serializer_class()`方法来获取当前视图使用的序列化器类。 总之,DRF的action序列化提供了一种方便而强大的方式来处理API的请求和操作。通过定义视图和序列化器,并将它们联系起来,我们可以在开发API时更加高效和灵活。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值