我只是想和Django一起练习。我试着做了一个简单的应用程序,让你上传一个图像,并返回像素化的版本。我有两个视图:一个显示表单,另一个处理图像并返回结果。问题是提出了“禁止(403)”,而不是结果。失败原因: CSRF令牌丢失或不正确。
urls.py
from django.conf.urls import url
from . import views
urlpatterns = [
url(r'^$', views.index, name='index'),
url(r'^result/$', views.pixelate, name='pixelate')
]views.py
from django.http import HttpResponse
from django.shortcuts import render_to_response
from .forms import UploadImageForm
from .pixelate import pixelate_image
def index(request):
form = UploadImageForm()
return render_to_response('pixelate/index.html', {'form': form})
def pixelate(request):
form = UploadImageForm(request.POST, request.FILES)
if form.is_valid():
response = HttpResponse(content_type='image/png')
response['Content-Disposition'] = 'filename="image.png"'
img = pixelate_image(request.FILES['image'])
response.write(img)
return responsepixelate.py
from PIL import Image
from io import BytesIO
def pixelate_image(img, pixelSize=9):
buffer = BytesIO()
p = Image(buffer)
image = p.open(img)
image = image.resize((image.size[0]/pixelSize, image.size[1]/pixelSize), Image.NEAREST)
image = image.resize((image.size[0]*pixelSize, image.size[1]*pixelSize), Image.NEAREST)
image.save()
final_image = buffer.getvalue()
buffer.close()
return final_imageforms.py
from django import forms
class UploadImageForm(forms.Form):
image = forms.ImageField()index.html
<form action="{% url 'pixelate:pixelate' %}" method="post">
{% csrf_token %}
{{ form }}
<input type="submit" value="Submit" />
</form>发布于 2015-10-19 14:26:56
index.html
<form action="{% url 'pixelate:pixelate' %}" method="post" enctype="multipart/form-data">
{% csrf_token %}
{{ form }}
<input type="submit" value="Submit" />
</form>https://stackoverflow.com/questions/33216939
复制相似问题