我正在创建一个小型企业门户网站。将有计算机数据库,其中包含有关公司中所有计算机的信息。我正在创建一个用于编辑计算机属性的 WTForm。我有一个包含计算机属性的表格的页面。每行都有特殊按钮。当用户按下其中一个时,我想显示一个页面,其中包含从数据库中获取的默认值。当我在 View 函数中编辑默认值时,出现错误:
The CSRF token is missing.
我的 View 函数:
def edit_computer(computer_id):
if admin_can() or sysadmin_can():
computer = models.Computer.query.filter_by(id=computer_id).one()
user = models.User.query.filter_by(id=computer.user_id).one()
email = user.email
form = forms.EditComputerForm()
form.email.default = user.email
form.type_.default=computer.type_
form.model.default = computer.model
form.cpu.default = computer.cpu
form.ram.default = computer.ram
form.rom.default = computer.rom
form.os.default = computer.os
form.supplements.default = computer.supplements
form.process()
if form.validate_on_submit():
...
当我不设置默认值(删除这个↓)时,代码工作正常
form.email.default = user.email
form.type_.default=computer.type_
form.model.default = computer.model
form.cpu.default = computer.cpu
form.ram.default = computer.ram
form.rom.default = computer.rom
form.os.default = computer.os
form.supplements.default = computer.supplements
form.process()
表格:
class EditComputerForm(FlaskForm):
email = EmailField("Owner's E-Mail",
validators=[DataRequired(), Email()])
type_ = SelectField('type',
choices=[('Notebook', 'Notebook'), ('PC', 'PC')])
model = StringField('Model')
cpu = StringField('CPU')
ram = StringField('RAM')
rom = StringField('ROM')
os = StringField('OS')
supplements = TextAreaField('Supplements')
submit = SubmitField('Edit')
HTML:
{% extends 'base.html' %}
{% import 'bootstrap/wtf.html' as wtf %}
{% block app_content %}
<h3>Edit computer's properties {{ add_title }}</h3>
<hr>
{{ wtf.quick_form(form, button_map={'submit': 'primary'}) }}
{% endblock %}
{% block app_windows %}{% endblock %}
如何解决这个错误? WTForm 现在不工作。
最佳答案
破坏 csrf 过程的是 form.process()
。
要动态设置表单值,我建议您使用数据属性,而不是默认属性。这样您就不必调用 form.process()
。
form.email.data= user.email
form.type_.data=computer.type_
form.model.data= computer.model
form.cpu.data= computer.cpu
form.ram.data= computer.ram
form.rom.data= computer.rom
form.os.data= computer.os
form.supplements.data= computer.supplements
关于python - 如何修复 Flask-WTForms 中的 "The CSRF token is missing",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57328711/