从具有不同名称的数据值设置序列化程序字段(ModelSerizer 的自定义字段映射)



>我有一个请求模型并遵循

class TruRouteRequest(models.Model):
msisdn = models.CharField('Subscriber international MSISDN ', max_length=25)
sessionid = models.CharField(max_length=100, unique=True)
msg_type = models.CharField(max_length=255)
msg = models.CharField(max_length=255)

我未能将模型字段的名称写为"type",所以我写了"msg_type"。我有一个用于上述模型的模型序列化程序。 我收到的数据具有必填字段"类型"。如何将序列化程序数据中的type映射到msg_type以避免调用有效时出现此错误

>> serializer = TruRouteRequestSerializer(data=request.data)
>> serializer.data 
>> {'msisdn': 'M', 'sessionid': 'S', 'msg': 'MSG'}
>> request.data
>> {'msisdn': 'M', 'type': 'T', 'sessionid': 'S', 'msg': 'MSG'} # there is type
>> serializer.is_valid()
>> False
>> serializer.errors
>> {'msg_type': [ErrorDetail(string='This field is required.', code='required')]}

您可以在序列化程序中显式定义type字段,并使用source参数将其映射到msg_type字段:

class TruRouteRequestSerializer(serializers.ModelSerializer):
type = serializers.CharField(source='msg_type')
class Meta:
model = TruRouteRequest
fields = ['type', ...]

相关内容

最新更新