2014-10-31 5 views
0

Form.is_valid() всегда возвращает false. Вот мой код.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> 

Я использую пакет Джанго называется Джанго-ajaximage и их пользовательских виджетов (AjaxImageWidget), вероятно, произвольный текст виджет

class AjaxImageWidget(widgets.TextInput): 

Спасибо вам help

+0

Где находится объект формы? Где его класс? Кроме того, введите свой код правильно. – Marcin

+0

ваш 'super' on Post init выглядит странно для меня – Anzel

+1

Ваш класс модели полностью сломан. Этот метод '__init__' активно запрещает вам создавать заполненный экземпляр или загружать его из db. Вы должны удалить его полностью. –

ответ

1

Вам не нужен init на вашем классе модели. Кроме того, значение null = False является значением по умолчанию. Я не уверен, что текст «admin» будет по умолчанию для пользователя с именем пользователя admin. Вы должны были бы сделать:

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

Вы можете также включать в себя назначение плаката в создании объекта, как так:

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

сделать форму проверки вам нужно поставить пустой = True в поле следующим образом:

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

I чюо uld также составляют форму ModelForm:

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

Спасибо за совет, но форма до сих пор не проверяется –

+1

Большое спасибо, а также за использование того же пользовательского виджета. Я добавил это widgets = {1 post_image: } –

Смежные вопросы