在我的django应用程序中,即使添加与管理应用程序中相同的数据,表单永远不会返回true。我model.py样子:Django表单is_valid始终为假
from django.db import models
from django.db.models import ImageField, signals
from django.dispatch import dispatcher
from django.forms import ModelForm
# Create your models here.
class Image(models.Model):
emailAddress = models.EmailField(max_length=75)
image = ImageField(upload_to='photos')
caption = models.CharField(max_length=100)
class UploadForm(ModelForm):
class Meta:
model = Image
我views.py看起来像:
from django.http import HttpResponse, HttpResponseRedirect
from django.shortcuts import render_to_response
from competition.models import Image, UploadForm
# Create your views here.
def index(request):
images = Image.objects.all().order_by('emailAddress')
return render_to_response('images/index.html', {'images': images})
def uploadImage(request):
if request.method == 'POST': # If the form has been submitted...
form = UploadForm(request.POST) # A form bound to the POST data
if form.is_valid(): # All validation rules pass
emailAddress = form.cleaned_data['emailAddress']
image = form.cleaned_data['image']
caption = form.cleaned_data['caption']
i = Image(emailAddress=emailAddress, image = image, caption = caption)
i.save()
return HttpResponseRedirect('../image/')
else:
return render_to_response('images/upload.html', {'form': form})
else:
form = UploadForm() # An unbound form
return render_to_response('images/upload.html', {'form': form})
我的模板是这样的:
<html>
<body>
<form enctype="multipart/form-data" action="/image/uploadImage" method="post">{% csrf_token %}
{{ form.as_p }}
<input type="submit" value="Submit" />
</form>
</body>
</html>
我可以得到它正常工作,如果我使用管理员应用程序,但需要一个通用的形式,这不起作用,因为它不断要求电子邮件地址或图像(错误出现在图像字段上方)。那么为什么我的表单可能无效?
添加CSRF令牌的形式。 – 2012-01-02 15:31:38
@Cat Plus Plus,我添加了CSRF令牌,错误仍在发生。为什么这会有所作为?我认为is_valid的想法是检查数据的有效性。 – Dean 2012-01-02 15:41:48