form.is_valid(): 始终返回假

0 投票
1 回答
758 浏览
提问于 2025-04-30 20:33

Form.is_valid() 总是返回 false。以下是我的代码。

#urls.py
url(r'^create/', "app.views.createpost", name="createpost"),

这是我的 models.py 文件

class Post(models.Model):
    """docstring for Post"""
    post_image = AjaxImageField(upload_to='posts', max_width=200, max_height=200, crop=True, null= False, default='site_media/media/BobMarley/bob1.jpg')
    poster = models.ForeignKey(User, null= False, default=User.objects.get(username="admin")

这是我的 forms.py 文件

#forms.py
class AjaxImageUploadForm(forms.Form):
    image = forms.URLField(widget=AjaxImageWidget(upload_to='posts'))    

view.py 文件内容

#views.py
def createpost(request):

    if request.method == 'POST':
        form = AjaxImageUploadForm(request.POST, request.FILES)
        if form.is_valid():
            newpost = Post(post_image = request.FILES['image'])
            newpost.poster = request.user
            newpost.save()

            return HttpResponseRedirect('/create/')


    else:
        form = AjaxImageUploadForm() # An empty, unbound form


    posts = Post.objects.all()

    return render_to_response('create.html',{'posts': posts, 'form': form},context_instance=RequestContext(request))

模板内容

#create.html
{% block extra_head %}    
    {{ form.media }}
{% endblock %}
{% block body %}
    <form method="POST" enctype="multipart/form-data" action="{% url "createpost" %}">      
        {% csrf_token %} 
        {{ form.errors}}
        {{ form.as_p }}
        <button type="submit" name='image'>Upload</button>
    </form>   
{% endblock %}

这个表单从来都是无效的,打印出的错误是“这个字段是必填的。”而这个表单小部件是这样创建的

<tr><th><label for="id_image">Image:</label></th><td><ul class="errorlist"><li>This field is required.</li></ul>
<div class="ajaximage"><a class="file-link" target="_blank" href=""> <img class="file-img" src=""></a> <a class="file-remove" href="#remove">Remove</a>
<input class="file-path" type="hidden" value="" id="id_image" name="image" /> <input type="file" class="file-input" name="image"/> <input class="file-dest" type="hidden" name="image" value="/ajaximage/upload/posts/0/0/0"> <div class="progress progress-striped active"> <div class="bar"></div></div>    
</div>
</td></tr>

我正在使用一个叫做 django-ajaximage 的 Django 包,它们的自定义小部件(AjaxImageWidget)可能是一个自定义的文本小部件

class AjaxImageWidget(widgets.TextInput):

谢谢你的帮助

暂无标签

1 个回答

1

你在模型类里不需要写init这个东西。而且,null=False其实是默认的设置。我不太确定文本'admin'会不会默认指向用户名为admin的用户。你需要这样做:

default=User.objects.get(username="admin")

你还可以在创建对象的时候直接指定发布者,像这样:

newpost = Post(post_image=request.FILES['image'], poster=request.user)

为了让表单验证通过,你需要在字段里加上blank=True,像这样:

poster = models.ForeignKey(User, blank=True, default=User.objects.get(username="admin"))

我还建议把表单做成一个ModelForm:

class AjaxImageUploadForm(forms.ModelForm):
    class Meta:
        model=Post
        exclude=['poster',]

撰写回答