本文主要是介绍Django序列化器中validate没起作用?validate的触发时机,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
今天上班的时候分配了一个任务,是修复前端的一个提示优化,如下图所示:
按照以往的经验我以为可以直接在validate上进行校验,如何抛出一个异常即可 ,例如:
class CcmSerializer(serializers.ModelSerializer):class Meta:model = Ccmfields = "__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()方法。如下:
class CcmSerializer(serializers.ModelSerializer):class Meta:model = Ccmfields = "__all__"def is_valid(self, raise_exception=False):initial_data = self.initial_dataif 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(),就会触发该重写的方法,效果如下:
这篇关于Django序列化器中validate没起作用?validate的触发时机的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!