Flask WTForms SelectField 获取当前选中项
Flask WTForms SelectField get currently selected item
我在提交时无法在 Flask 应用程序的 WTForms 页面中获取当前选定的项目。 form.tableselector.data 值在提交时始终等于 1,无论选择了 SelectField 中的哪个项目(并且所有选择都有一个唯一的 table id,来自表单的 1-10 (1, 'table_name') 其中 1 是一个整数。
这是当前代码:
views.py
from flask import session
def view(self):
form = Tableset(request.form)
if request.method == 'POST' and form.validate():
#form.tableselector.data always returns 1 no matter which item is selected?
session['table_id'] = form.tableselector.data
form.py
class MyBaseForm(Form):
#see https://wtforms.readthedocs.io/en/latest/csrf.html
class Meta:
csrf = True
csrf_class = SessionCSRF
csrf_secret = app.config.get('SECRET_KEY')
@property
def csrf_context(self):
return session
class Tableset(MyBaseForm):
tableselector = SelectField(label = 'Table', choices = [], coerce=int, id='select_table')
submit = SubmitField('Submit')
def validate(self):
if len(self.tableselector.choices) == 0:
return False
return True
tableview.html
<form role="form" action="{{ url_for('app.table_view') }}" method="post">
{{ form.csrf_token }}
<div class="form-group">
{{ form.tableselector.label }}
{{ form.tableselector }}
</div>
我注意到在调试表单时,wtf 元对象 csrf 属性 等于 True,所以我知道 CSRF 正在工作。
问题是我在视图中调用了错误的参数。
看这里:How to obtain values of request variables using Python and Flask
使用:
if request.method == 'POST' and form.validate():
session['table_id'] = request.form.get('tableselector')
我在提交时无法在 Flask 应用程序的 WTForms 页面中获取当前选定的项目。 form.tableselector.data 值在提交时始终等于 1,无论选择了 SelectField 中的哪个项目(并且所有选择都有一个唯一的 table id,来自表单的 1-10 (1, 'table_name') 其中 1 是一个整数。
这是当前代码:
views.py
from flask import session
def view(self):
form = Tableset(request.form)
if request.method == 'POST' and form.validate():
#form.tableselector.data always returns 1 no matter which item is selected?
session['table_id'] = form.tableselector.data
form.py
class MyBaseForm(Form):
#see https://wtforms.readthedocs.io/en/latest/csrf.html
class Meta:
csrf = True
csrf_class = SessionCSRF
csrf_secret = app.config.get('SECRET_KEY')
@property
def csrf_context(self):
return session
class Tableset(MyBaseForm):
tableselector = SelectField(label = 'Table', choices = [], coerce=int, id='select_table')
submit = SubmitField('Submit')
def validate(self):
if len(self.tableselector.choices) == 0:
return False
return True
tableview.html
<form role="form" action="{{ url_for('app.table_view') }}" method="post">
{{ form.csrf_token }}
<div class="form-group">
{{ form.tableselector.label }}
{{ form.tableselector }}
</div>
我注意到在调试表单时,wtf 元对象 csrf 属性 等于 True,所以我知道 CSRF 正在工作。
问题是我在视图中调用了错误的参数。
看这里:How to obtain values of request variables using Python and Flask
使用:
if request.method == 'POST' and form.validate():
session['table_id'] = request.form.get('tableselector')