我们在开发中使用REST,并且在我们的应用程序上有一个站点管理功能。名称,描述,标题和图标将来自API。我们还在另一个前端应用程序上有一个管理界面,可以对API进行更改。
这是 models.py :
class Website(models.Model):
icon = models.ImageField()
name = models.CharField(max_length=100)
second_name = models.CharField(max_length=100)
description = models.TextField()
这是 serializers.py:
class WebsiteSerializer(serializers.ModelSerializer):
class Meta:
model = Website
fields = '__all__'
以下是 views.py :
class WebsiteViewSet(mixins.RetrieveModelMixin,
mixins.ListModelMixin,
mixins.UpdateModelMixin,
viewsets.GenericViewSet):
model = Website
queryset = Website.objects.filter()
permission_classes = []
renderer_classes = [renderers.JSONRenderer]
serializer_class = WebsiteSerializer
def list(self, request):
serializer = self.get_serializer(self.queryset.first())
data = serializer.data
return Response(data)
我的问题是图标。更新图标时,它可以正常工作。但是它返回'提交的数据不是文件。检查表单上的编码类型。“验证错误,如果您没有更改图标..
这是获取API数据时返回的内容的示例:
{
"id": 1,
"icon": "http://192.168.0.110:8000/upload/%E5%B1%8F%E5%B9%95%E5%BF%AB%E7%85%A7_2017-02-23_%E4%B8%8B%E5%8D%886.02.42_zbAld6c.png",
"name": "Hello",
"second_name": "World",
"description": "Bacon Loren Ipsum Porsum"
}
我认为这里的问题是,当我们不更改前端的图标时,URL字符串值是返回的值。我们如何解决这个问题?
P.S。
答案 0 :(得分:2)
取决于您的错误,我认为问题是select DISTINCT(tab1.name) FROM (SELECT * FROM myTable WHERE name = 'Accessories' UNION SELECT * FROM myTable WHERE name LIKE '%Accessories') as tab1
是必填字段。因此,您应该在表单中使用ImageField
进行跳过验证。您还可能需要blank=True
来解析图像。
MultiPartParser