ImageField を使用して単純なモデルを作成しました。文書化され、ファイルをアップロードできる django-rest-framework + django-rest-swagger を使用して API ビューを作成したいと考えています。
これが私が得たものです:
models.py
from django.utils import timezone
from django.db import models
class MyModel(models.Model):
source = models.ImageField(upload_to=u'/photos')
is_active = models.BooleanField(default=False)
created_at = models.DateTimeField(default=timezone.now)
def __unicode__(self):
return u"photo {0}".format(self.source.url)
serializer.py
from .models import MyModel
class MyModelSerializer(serializers.ModelSerializer):
class Meta:
model = MyModel
fields = [
'id',
'source',
'created_at',
]
views.py
from rest_framework import generics
from .serializer import MyModelSerializer
class MyModelView(generics.CreateAPIView):
serializer_class = MyModelSerializer
parser_classes = (FileUploadParser, )
def post(self, *args, **kwargs):
"""
Create a MyModel
---
parameters:
- name: source
description: file
required: True
type: file
responseMessages:
- code: 201
message: Created
"""
return super(MyModelView, self).post(self, *args, **kwargs)
urls.py
from weddings.api.views import MyModelView
urlpatterns = patterns(
'',
url(r'^/api/mymodel/$', MyModelView.as_view()),
)
私にとって、これはかなり単純なはずです。ただし、アップロードを機能させることはできません。私はいつもこのエラー応答を受け取ります:
django-rest-frameworkのドキュメントのこの部分を読みました:
If the view used with FileUploadParser is called with a filename URL keyword argument, then that argument will be used as the filename. If it is called without a filename URL keyword argument, then the client must set the filename in the Content-Disposition HTTP header. For example Content-Disposition: attachment; filename=upload.jpg.
ただし、ヘッダーは Request Payload プロパティで django-rest-swagger によって渡されています (chrome コンソールから)。
さらに情報が必要な場合は、お知らせください。
Django==1.8.8
、djangorestframework==3.3.2
およびを使用してdjango-rest-swagger==0.3.4
います。