我有以下代码,并且正在提交表单。当我点击提交按钮时,我的表单验证会打印出来False
。我已经检查并确保我包含了不同帖子中的所有内容,但我无法对其进行验证。我做错了什么吗?
@app.route('/index.html', methods=['GET', 'POST'])
def index():
user = {'nickname': 'Rafa'}
form = FilterForm()
print("about to validate", file=sys.stderr)
if form.validate_on_submit():
print("validated", file=sys.stderr)
filters_array = form.filter.split(',')
streaming(filters_array)
response = {"response", "yes"}
redirect("/authenticate")
return render_template('index.html',
title="Home",
user=user,
form=form)
class FilterForm(Form):
filter = StringField('filter', validators=[DataRequired()])
这是我的 Jinja 文件
{% block content %}
<h1> I have successfully navigated to the title pagee </h1>
<h1> Hello, {{user.nickname}}!</h1>
<h1> Get Tweets </h1>
<p> Please enter a comma delimited list of filters</p>
<form action="" method="post" name="login">
{{form.filter(size=80)}}
<input type="submit" value="Get Tweets!">
</form>
{% endblock %}
FilterForm
不应缩进与def index()
。更重要的是,你没有csrf_token
以你的形式。这将阻止它验证。
将其添加到您的表单中:
{{ form.csrf_token }}
最后,当使用 wtforms 进行验证时,错误将填充到表单对象中。所以经过一个if validate
,尝试打印form.errors
然后你就会知道到底出了什么问题。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)