我想用带有WTForms的烧瓶创建一个应用程序。
在controller.py中我有:
@mod_private.route('/portfolio/', methods=['GET', 'POST'])
@login_required
def portfolio():
print "in portfolio" # I read this
form = CreateCoinsForm(request.form)
if request.method == 'POST' and form.validate_on_submit():
print form.coins.data #I cannot take this value
return render_template("private/portfolio.html",form=form)
return render_template("private/portfolio.html",form=form)
form.py中的:
class CreateCoinsForm(Form):
coins = IntegerField('coins',
[DataRequired('num required'),
NumberRange(min=0, max=10)])
和模板
<form method="post" action="/private/portfolio/" accept-charset="UTF-8" role="form">
<p> {{ form.coins }}</p>
<p><input type=submit value=Generate>
</form>
我的问题,正如我在代码中写的那样,我无法检索插入模板中的字符串。
答案 0 :(得分:2)
您的问题表明您在表单上使用了内置的CSRF保护,而您的表单实际上并未经过验证,因为您还没有包含CSRF令牌。
尝试调整模板:
<form method="post" action="/private/portfolio/" accept-charset="UTF-8" role="form">
{{ form.hidden_tag() }}
<p> {{ form.coins }}</p>
<p><input type=submit value=Generate>
</form>