python - 如何修复 Flask-WTForms 中的 "The CSRF token is missing"

标签 python python-3.x flask flask-wtforms wtforms

我正在创建一个小型企业门户网站。将有计算机数据库,其中包含有关公司中所有计算机的信息。我正在创建一个用于编辑计算机属性的 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/

相关文章:

python - 摆脱天体中的单位

python - Python Flask 上的同步 api 任务

python - 使用 pymongo 和 flask 插入数据

jquery - Django:具有多个查询集的 jQuery 自动完成

Python HDFS 给出不正确的文件大小

mysql - 使用 datetime.date 索引索引 Pandas 数据框会导致 KeyError

python - Flask:如何处理应用程序/八位字节流

python - Ruby 是否支持条件正则表达式

python - HTML <li> 有什么限制吗?

python - 线程错误 : AttributeError: 'NoneType' object has no attribute '_initialized'