从应用程序(iOS android 等)而不是网络表单发布。
class someImage(models.Model):
image = models.ImageField(upload_to= settings.SHARE_IMAGE_UPLOAD_PATH)
@csrf_exempt
def saveImage(request):
如何写视图?它在发布请求中接收图像。我发现的每件事都与形式相关(服务器新手)
从应用程序(iOS android 等)而不是网络表单发布。
class someImage(models.Model):
image = models.ImageField(upload_to= settings.SHARE_IMAGE_UPLOAD_PATH)
@csrf_exempt
def saveImage(request):
如何写视图?它在发布请求中接收图像。我发现的每件事都与形式相关(服务器新手)
仅仅因为您没有使用实际的 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'])
编辑: 请使用上面选择的答案 - 下面的代码适用于该问题,但不推荐。
您上传的图片文件可以在以下位置找到:
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。