我需要上传一个文件和一些与之关联的JSON。但我不明白如何保存不同的部分,特别是JSON部分,即我能够保存图像而不是JSON。
我read that I need to use a MultiPartParser但我无法弄清楚如何将它正确地集成到我的序列化程序类中。
以下是我的服务器正在接收的多部分请求:
<QueryDict: {'geo': ['{"point" : { "type:" : "Point", "coordinates" : [11.51350462236356, -22.70903491973877]}}'], 'picture': [<TemporaryUploadedFile: photo3.jpg (image/*)>]}>
以下是观点:
class UserUploadedPicture(APIView):
def post(self, request, format=None):
print(request.data)
print("\n\n\n")
serializer = PictureSerializer(data=request.data)
if serializer.is_valid():
serializer.save()
return JsonResponse(serializer.data)
return JsonResponse(serializer.errors, status=400)
这是序列化器:
class PictureSerializer(GeoFeatureModelSerializer):
class Meta:
model = Pictures
geo_field = "point"
fields = ('picture', 'processed', 'flagged', 'point')
以下是模型:
class Pictures(models.Model):
objects = models.GeoManager()
picture = models.ImageField(null=True, default=None, blank=True)
processed = models.BooleanField(default=False)
flagged = models.BooleanField(default=False)
point = models.PointField(null=True, default=None, blank=True)
有人可以告诉我如何正确序列化point
字段吗?也许我需要更改JSON格式?也许我需要更改序列化器?
答案 0 :(得分:4)
对于集成MultiPartParser,它是通过视图完成的,因为它负责接收请求并处理它,而不是序列化程序。
您正在使用基于类的视图,并使用parser_classes
属性定义解析器,如您提供的官方文档的相同链接中所述。
所以你的观点变成了:
class UserUploadedPicture(APIView):
parser_classes = (MultiPartParser, )
def post(self, request, format=None):
print(request.data)
print("\n\n\n")
serializer = PictureSerializer(data=request.data)
if serializer.is_valid():
serializer.save()
return JsonResponse(serializer.data)
return JsonResponse(serializer.errors, status=400)
关于PointField
的序列化程序,请检查this SO answer