是的,我正在学习如何制作一个简单的图像上传表单以将图像上传到 MEDIA_ROOT。表单呈现良好,我没有收到任何错误,但该文件未显示在 MEDIA_ROOT 目录中。如果遵循文档示例但无法使其工作,我知道这是因为我没有正确理解 django 文件上传处理。这是我的代码:
forms.py
from django import forms
class UploadImageForm(forms.Form):
image = forms.ImageField()
views.py
def merchant_image_upload(request):
if request.method == 'POST':
form = UploadImageForm(request.POST, request.FILES)
if form.is_valid():
FileUploadHandler(request.FILES['image'])
return HttpResponseRedirect('/dashboard/gallery')
else:
form = UploadImageForm()
return render_to_response('gallery.html', RequestContext(request, {'form': form}))
模板文件
{% extends 'base.html' %}
{% block main %}
<form action="{% url scvd.views.merchant_image_upload %}" method="post">{% csrf_token %}
{{ form.image }}
<input type="submit" value="Upload" />
</form>
{% endblock %}
希望这些信息足以获得帮助。请让我知道我还能提供什么。谢谢你,我真的很感谢你的帮助。
您不需要将其附加到模型,如 Matt S 所说,如果您的表单设置正确,request.FILES 包含图像的所有数据。
您需要确保使用enctype="multipart/form-data"
在您的元素中,如文档所述:https://docs.djangoproject.com/en/dev/ref/forms/api/#binding-uploaded-files-to-a-form https://docs.djangoproject.com/en/dev/ref/forms/api/#binding-uploaded-files-to-a-form
除此之外,请阅读有关文件上传的文档:https://docs.djangoproject.com/en/dev/topics/http/file-uploads/ https://docs.djangoproject.com/en/dev/topics/http/file-uploads/
您需要的一切都在那里有详细记录。希望这可以帮助!
编辑OP请求有关文件上传的更多信息
来自文档:
大多数时候,您只需将请求中的文件数据传递到
将上传的文件绑定到表单中所述的表单。这个会
看起来像:
from django.http import HttpResponseRedirect
from django.shortcuts import render_to_response
# Imaginary function to handle an uploaded file.
from somewhere import handle_uploaded_file
def upload_file(request):
if request.method == 'POST':
form = UploadFileForm(request.POST, request.FILES)
if form.is_valid():
handle_uploaded_file(request.FILES['file'])
return HttpResponseRedirect('/success/url/')
else:
form = UploadFileForm()
return render_to_response('upload.html', {'form': form})
他们有一个例子告诉你如何写handle_uploaded_file
功能:
def handle_uploaded_file(f):
destination = open('some/file/name.txt', 'wb+')
for chunk in f.chunks():
destination.write(chunk)
destination.close()
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)