class serializer_blahblah(serializers.ModelSerializer):
"""Serializer for ProfileUsefulRecommendations."""
profile_id = serializers.UUIDField()
recommendation_id = serializers.UUIDField()
class Meta:
"""Meta class."""
fields = (
"id",
"profile_id",
...
这个序列化器一切都很完美,但是我决定添加对象级验证
这是发生的事情:
def validate(self, data):
recommendation_id = str(data["recommendation_id"])
print("recommendation: ", recommendation_id)
validate_recommendation_id(recommendation_id=recommendation_id)
print(validate_recommendation_id(recommendation_id=recommendation_id))
return data
打印输出:
recommendation: 3a232d0d-0705-4775-8bae-0e2f3d69c96c
它甚至不识别该功能......
但是,如果我在各个字段序列化器中使用完全相同的函数,则效果会很好。但简而言之,我需要它作为对象级别
添加了函数代码:
def validate_recommendation_id(recommendation_id):
try:
Recommendation.objects.get(id=recommendation_id)
except Recommendation.DoesNotExist as exception:
raise serializers.ValidationError(
{f"{recommendation_id}": "does not exist"}
) from exception
return recommendation_id
这就是为每个字段添加验证的方式。
class serializer_blahblah(serializers.ModelSerializer):
recommendation_id = serializers.UUIDField()
def validate_recommendation_id(self, recommendation_id):
return recommendation_id
你没有在
validate
方法中调用它。
实际上,伙计们,我已经想出了这样的解决方案。 我定义了而不是验证函数
Class CheckIfObjectHasId(queryset, lookup_object)
后来我调用了序列化器:
class serializer_blahblah(serializers.ModelSerializer):
"""Serializer for ProfileUsefulRecommendations."""
profile_id = serializers.UUIDField(
validators=[
CheckIfObjectHasId(queryset=Profile.object.all(), lookup_object="id"
]
)
def 验证(自身,数据): 如果数据['min_pay'] >= 数据['max_pay']: raise serializers.ValidationError({'message': 'max_pay 不能小于 min_pay'}) 别的: 返回 super().validate(data)
尝试一下,这可能对你有帮助..