Django序列化器中is_valid和validate

今天上班的时候分配了一个任务,是修复前端的一个提示优化,如下图所示:

按照以往的经验我以为可以直接在validate上进行校验,如何抛出一个异常即可 ,例如:

python 复制代码
class CcmSerializer(serializers.ModelSerializer):

    class Meta:
        model = Ccm
        fields = "__all__"

    def validate(self, attrs):
        print(1111)
        name = attrs.get("name")
        identification = attrs.get("identification")
        description = attrs.get("description")
        if len(name) > 64:
            raise serializers.ValidationError(
                f"CCM名称长度不能超过64个字符")
        if len(identification) > self.Meta.model._meta.get_field('identification').max_length:
            raise serializers.ValidationError(
                f"CCMID长度不能超过64个字符")
        return attrs

但是,当在视图中执行serializer.is_valid()的时候,validate()函数并没有触发,我非常疑惑,于是乎打断点进行测试,最终发现validate()其实是当serializer.is_valid()返回True的并且执行serializer.save()的时候才会触发的。所以要想在校验字段的时候抛出自定义的异常信息,就需要重写is_valid()方法。如下:

python 复制代码
class CcmSerializer(serializers.ModelSerializer):

    class Meta:
        model = Ccm
        fields = "__all__"

    def is_valid(self, raise_exception=False):
        initial_data = self.initial_data
        if len(initial_data.get("name")) > NORMAL:
            raise serializers.ValidationError(f"CCM名称长度不能超过{NORMAL}字符")
        if len(initial_data.get("identification")) > NORMAL:
            raise serializers.ValidationError(f"CCM标识长度不能超过{NORMAL}字符")
        return super().is_valid(raise_exception)

经过修改后,在视图中调用serializer.is_valid(),就会触发该重写的方法,效果如下:

相关推荐
葫芦和十三6 小时前
图解 MongoDB 21|选举与 failover:Primary 是怎么选出来的
后端·mongodb·agent
GetcharZp7 小时前
26k Star 开源内网穿透神器 NetBird,一分钟实现全球设备互联!
后端
考虑考虑7 小时前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯8 小时前
GoF设计模式——中介者模式
java·后端·spring·设计模式
金銀銅鐵9 小时前
[Python] 基于欧几里得算法,实现分数约分计算器
python·数学
lizhongxuan10 小时前
多Agent之间的区别
后端
Lyn_Li11 小时前
Kaggle Top 5 | 198只股票、200条数据的金融预测——BattleFin高分方案从零复现
python·kaggle·比赛复盘·金融预测
杨充13 小时前
1.面向对象设计思想
后端
IT_陈寒13 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
systemPro13 小时前
2.6亿条设备数据,历史查询从超时到50ms,我做了什么
后端