Flask-WTF validate()方法是否不应覆盖其他验证?

时间:2018-08-29 20:21:01

标签: python flask flask-wtforms

我正在忙于一个plurasight课程,该课程旨在处理Flask-wtf中的错误。唯一的问题是课程是“过时的”。它是2014年制作的。在视频中,老师演示了如何在类中定义validate()方法来在我调用form.validate_on_submit()时首先使用它。这是代码:

from flask_wtf import FlaskForm
from wtforms.fields import StringField
from wtforms.fields.html5 import URLField
from wtforms.validators import DataRequired, url


class BookmarkForm(FlaskForm):
    url = URLField('url', validators=[DataRequired(), url()])
    description = StringField('description')

    def validate(self):
        if not self.url.data.startswith("http://") or self.url.data.startswith("https://"):
            self.url.data = "http://" + self.url.data

        if not FlaskForm.validate(self):
            return False

        if not self.description.data:
            self.description.data = self.url.data

        return True

这是我的观点:

@app.route('/add', methods=['GET', 'POST'])
def add():
    form = BookmarkForm(request.form)
    if form.validate_on_submit():
        url = form.url.data
        description = form.description.data

        store_bookmark(url, description)
        flash('Stored bookmark {}'.format(description))
        return redirect(url_for('index'))
    return render_template('add.html', form=form)

问题是,Flask-wtf不允许我提交类似google.com的网址。仅采用以下形式:http://www.google.com

基于this description 它应该像这样工作:

validate_on_submit()

仅在提交表单后才调用validate()。这是form.is_submitted()和form.validate()的快捷方式

但事实并非如此。仍然不允许我输入没有http://的URL。 我在文档中没有找到任何解决方案,here是一个stackoverflow问题,但是没有答案,而且它已经3年了。请帮助我找出我做错了什么!

1 个答案:

答案 0 :(得分:0)

渲染时,wtforms.UrlField创建一个<input type="url">元素。现代浏览器仅在网址输入元素中接受valid absolute or relative urls。像“ google.com”这样的字符串不是有效的绝对或相对网址(它是主机名),因此浏览器不允许您将其键入输入。

要解决此问题,请使用StringField而不是UrlField,以便呈现<input type="text">,并且浏览器不执行任何验证。

class BookmarkForm(FlaskForm):
    url = StringField('url', validators=[DataRequired(), url()])
    description = StringField('description')

有关浏览器方面的一些可能解决方案,另请参阅this question的答案。