【问题标题】:Flask-WTForms FileField Not ValidatingFlask-WTForms FileField 未验证
【发布时间】:2014-02-05 00:20:51
【问题描述】:

我正在尝试构建一个应用程序以使用 Flask 和 WTForms 的 FileField 表单字段将文件上传到 Web 服务器。该帖子正在成功通过,但我很好奇为什么 form.validate_on_submit() 每次都失败,即使特定的验证器都成功了。这是表单 (forms.py)、应用程序 (main.py) 和 html 模板 (upload.html) 的代码。

### forms.py   

from flask.ext.wtf import Form
from flask.ext.wtf.html5 import EmailField
from flask.ext.wtf.file import FileField, FileRequired, FileAllowed
from wtforms import validators, ValidationError, SubmitField

class UploadForm(Form):
  presentation = FileField('Presentation in Image Format', validators=[FileRequired(), FileAllowed(['jpg', 'png'], 'Images only!')])
  submit = SubmitField("Send")



### main.py

from forms import UploadForm
from flask import render_template, url_for, redirect, send_from_directory

@app.route('/upload/', methods=('GET', 'POST'))
  def upload():
    form = UploadForm()
    if form.validate_on_submit():
      filename = secure_filename(form.presentation.file.filename)
      print filename
      form.presentation.file.save(os.path.join('uploads/', filename))
      return redirect(url_for('uploads', filename=filename))
    filename = None
    return render_template('upload.html', form=form, filename=filename)

@app.route('/uploads/<filename>')
  def uploaded_file(filename):
    return send_from_directory(app.config['UPLOAD_FOLDER'], filename)



### upload.html
   {% for message in form.presentation.errors %}
     <div class="flash">{{ message }}</div>
   {% endfor %}
   <form action="/upload/" method="POST" enctype="multipart/form-data">
     {{ form.presentation.label }}
     {{ form.presentation }}
     {{ form.submit}}
   </form>

有谁知道为什么这可能无法验证?还是我不应该使用 validate_on_submit()?

【问题讨论】:

  • 使用form.validate()代替form.validate_on_submit()并将form = UploadForm()改为form = UploadForm(request.form)
  • 我试过这个 - 没用。此外,这一次它返回一条错误消息(以前它会发布没有任何错误消息)“无”,我只能假设是文件名,因为它没有经过验证。

标签: flask wtforms flask-wtforms


【解决方案1】:

Flask-WTF 默认启用 CRSF,如果您打印 form.errors,您将收到一条消息,告诉您需要 csrf 令牌。

解决办法很简单,把{{ form.csrf_token }}放在你的模板里,或者禁用表单的CSRF,但你真的不应该这样做。

<form action="/upload/" method="POST" enctype="multipart/form-data">
 {{ form.presentation.label }}
 {{ form.presentation }}
 {{ form.csrf_token }}
 {{ form.submit}}
</form>

还有一种快速的方法可以将每个隐藏字段添加到表单hidden_tags

<form action="/upload/" method="POST" enctype="multipart/form-data">
 {{ form.presentation.label }}
 {{ form.presentation }}
 {{ form.hidden_tag() }}
 {{ form.submit}}
</form>

【讨论】:

  • 很遗憾,我没有足够的积分来投票。虽然被接受为正确答案。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2021-12-09
  • 2016-05-30
  • 1970-01-01
  • 2022-12-20
  • 2014-01-21
  • 2021-01-30
  • 2023-02-02
相关资源
最近更新 更多