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(),就会触发该重写的方法,效果如下:

相关推荐
武子康5 分钟前
大数据-145 Apache Kudu 架构与实战:RowSet、分区与 Raft 全面解析
大数据·后端·nosql
间彧6 分钟前
Spring @ControllerAdvice详解与应用实战
后端
间彧10 分钟前
@ControllerAdvice与AOP切面编程在处理异常时有什么区别和各自的优势?
后端
测试-鹏哥23 分钟前
要将ITP集成到Jenkins Pipeline中,实现开发发版时自动触发自动化测试
运维·python·测试工具·ci/cd·jenkins
程序员三藏25 分钟前
Postman接口测试详解
自动化测试·软件测试·python·测试工具·职场和发展·接口测试·postman
L.EscaRC25 分钟前
Lua语言知识与应用解析
java·python·lua
间彧35 分钟前
什么是Region多副本容灾
后端
爱敲代码的北35 分钟前
WPF容器控件布局与应用学习笔记
后端
爱敲代码的北36 分钟前
XAML语法与静态资源应用
后端
清空mega38 分钟前
从零开始搭建 flask 博客实验(5)
后端·python·flask