7

从应用程序(iOS android 等)而不是网络表单发布。

class someImage(models.Model):
    image = models.ImageField(upload_to= settings.SHARE_IMAGE_UPLOAD_PATH)

@csrf_exempt
def saveImage(request):

如何写视图?它在发布请求中接收图像。我发现的每件事都与形式相关(服务器新手)

4

2 回答 2

16

仅仅因为您没有使用实际的 HTML 表单来提交数据并不意味着您不能使用 aModelForm来处理请求:

from django.http import HttpResponse, HttpResponseBadRequest, HttpResponseNotAllowed
from django.utils import simplejson

def upload_view(request):
    if request.method == 'POST':
        form = UploadForm(request.POST, request.FILES)
        if form.is_valid():
            form.save()
            result = {'success': True}
            return HttpResponse(simplejson.dumps(result), mimetype='application/json')
        else:
            return HttpResponseBadRequest()
    else:
       return HttpResponseNotAllowed(['POST'])
于 2012-01-11T17:52:22.050 回答
5

编辑: 请使用上面选择的答案 - 下面的代码适用于该问题,但不推荐。

您上传的图片文件可以在以下位置找到:

request.FILES['image'] # assuming input name is called 'image'

它不会返回一个 Image 对象,而是一个 UploadedFile 对象。您可以阅读这部分文档(我假设您使用的是 Django 1.3.x):https ://docs.djangoproject.com/en/1.3/topics/http/file-uploads/#handling-uploaded-files

它涵盖了 UploadedFile 对象中可用的字段和方法,也是手动处理文件上传的常用方法。您可以使用相同的方法将图像文件写入文件对象,然后将其保存到您的 ImageField。

以下代码应该可以工作,但它不是安全代码。我假设您正在使用 *nix 机器,如果没有,请将目标文件保存在其他地方。

@csrf_exempt
def saveImage(request):
    # warning, code might not be safe
    up_file = request.FILES['image']
    destination = open('/tmp/' + up_file.name , 'wb+')
    for chunk in up_file.chunks():
        destination.write(chunk)
    destination.close()
    img = someImage()
    img.image.save(up_file.name, File(open('/tmp/' + up_file.name, 'r')))
    img.save()
    # return any response you want after this

其他需要注意的事项:确保您的表单具有以下属性才能正常工作:

 <form enctype="multipart/form-data" ... >

我不记得这种用法是正常的,但实际上,建议使用 Forms。

于 2012-01-11T16:35:53.260 回答