文档章节

flask-wtf validate error

cdsc
 cdsc
发布于 2017/07/22 19:27
字数 701
阅读 79
收藏 0

描述

使用request.args.get方法获取web前段数据填充flask-wtf表单时,由于获取的值为unicode编码,导致flask-wtf验证失败。

问题排查

flask-wtf 后台的Form表单, selectField字段关联数据库,代码如下:

class ApplyReourceForm(FlaskForm):
    username = StringField('User Name')
    apply_pool_id = SelectField('Apply Pool Name', coerce=int)
    apply_date = StringField('Apply Date')
    audit_user_id = SelectField('Audit User Name', coerce=int)
    apply_reason = TextAreaField('Apply Reason')
    submit = SubmitField('Submit')
    save = SubmitField('Save')

    ''' SelectField字段关联数据库,在此初始化选项value值(其中User,ResourcePool 为数据库模型) '''
    def __init__(self, *args, **kwargs):
        super(ApplyReourceForm, self).__init__(*args, **kwargs)
        self.apply_pool_id.choices = [(pool.id, pool.name) for pool in
                                      ResourcePool.query.all()]
        self.audit_user_id.choices = [(audit_user.id, audit_user.username) for audit_user in
                                      User.query.all()]

调用view代码

@yarn.route('/apply', methods=['GET', 'POST'])
@login_required
def apply_resource_pool():
    resource_id = request.args.get('resource_id')
    form = ApplyReourceForm()
    form.username.data = current_user.username # form表单值预填充
    form.apply_pool_id.data = resource_id  #  form表单值预填充,值来自web前台
    form.apply_date.data = time.strftime('%Y-%m-%d %H:%M:%S')
    if form.validate_on_submit():
        if form.save.data:
            print 'click save button'
        elif form.submit.data:
            print 'click submit button'
    return render_template('yarn/apply_resource_pool.html', form=form)

前台form表单验证总是不通过,查看validate_on_submit 类,分别打印is_submitted() 及 validate()值

def validate_on_submit(self):
    """Call :meth:`validate` only if the form is submitted.
    This is a shortcut for ``form.is_submitted() and form.validate()``.
    """
    print 'submit: %s' % self.is_submitted()
    print 'validate: %s' % self.validate()
    return self.is_submitted() and self.validate()

执行结果:
submit: True
validate: False

触发了submit方法,但是表单验证未通过,继续查看validate方法:

def validate(self):
    """
    Validates the form by calling `validate` on each field, passing any
    extra `Form.validate_<fieldname>` validators to the field validator.
    """
    extra = {}
    for name in self._fields:
        inline = getattr(self.__class__, 'validate_%s' % name, None)
        if inline is not None:
            extra[name] = [inline]

    return super(Form, self).validate(extra) # 返回在这一句

继续查看super.validate()方法,在循环校验字段处依次打印每个字段的校验结果:

def validate(self, extra_validators=None):
    """
    Validates the form by calling `validate` on each field.

    :param extra_validators:
        If provided, is a dict mapping field names to a sequence of
        callables which will be passed as extra validators to the field's
        `validate` method.

    Returns `True` if no errors occur.
    """
    self._errors = None
    success = True
    for name, field in iteritems(self._fields):
        if extra_validators is not None and name in extra_validators:
            extra = extra_validators[name]
        else:
            extra = tuple()
        print extra  # 传入的校验方法
        if not field.validate(self, extra):
            print '------------------------ %s -------error--------------------------' % name
            success = False
    return success

执行结果:
()
()
------------------------ apply_pool_id -------error--------------------------
()
()
()
()
()
()

目前可以看出是apply_pool_id校验失败导致表单无法通过验证,在view处查看提交时表单的字段值及类型,代码如下:

print 'apply_pool_id: %s, %s' % (form.apply_pool_id.data, type(form.apply_pool_id.data))
print 'audit_user_id: %s, %s' % (form.audit_user_id.data, type(form.audit_user_id.data))

执行结果:
apply_pool_id: 1, <type 'unicode'>
audit_user_id: 1, <type 'int'>

发现apply_pool_id值类型为unicode与定义的int不符,导致表单验证失败,于是修改view视图,将参数强制转换为int类型:

resource_id = int(request.args.get('resource_id'))

再次提交表单,日志信息:
submit: True
()
()
()
()
()
()
()
()
validate: True
()
()
()
()
()
()
()
()
click submit button
apply_pool_id: 1, <type 'int'>
audit_user_id: 1, <type 'int'>

问题解决

发现验证已通过,以前没遇到过这种情况,网上也没找到对应的问题,所以在此记录一下。 PS:遇到问题还是要多去熟悉源码。

© 著作权归作者所有

共有 人打赏支持
cdsc
粉丝 0
博文 11
码字总数 7395
作品 0
深圳
程序员
私信 提问
设计模式 Template模式

在面向对象系统的分析与设计过程中经常会遇到这样一种情况: 一个流程可以分为A,B,C….多个步骤,但在具体的步骤中可能会有不同的情况出现,这时就Template模式就非常有用:

caoxinyu0205
2016/09/03
2
0
网站后端.Flask.实战-社交博客开发-flask-login认证用户?

用户模型 1.用户登录后认证状态需要被记录,这样浏览不同的页面才能记住这个状态,flask-login专门用来管理用户认证系统中的认证状态,且不依赖特定的认证机制 2.用户模型必须实现isauthenticat...

满满李
2016/06/26
499
0
(三)Flask 学习 —— web 表单

web 表单 回顾 在上一章节中,我们定义了一个简单的模板,使用占位符来虚拟了暂未实现的部分,比如用户以及文章等。 在本章我们将要讲述应用程序的特性之一–表单,我们将会详细讨论如何使用...

水果糖
2016/02/25
1K
0
falsk-web 表单

web 表单 回顾 在上一章节中,我们定义了一个简单的模板,使用占位符来虚拟了暂未实现的部分,比如用户以及文章等。 在本章我们将要讲述应用程序的特性之一–表单,我们将会详细讨论如何使用...

joker_bug
2017/07/12
0
0
最牛「CSRF防护」,带你进入大虾们的圈子!

简单理解 CSRF 什么是 CSRF? CSRF,通常称为跨站请求伪造,英文名 Cross-site request forgery 缩写 CSRF,是一种对网站的恶意攻击。一个跨站请求伪造攻击迫使登录用户的浏览器将伪造的HTT...

OneAPM蓝海讯通
2016/01/18
36
0

没有更多内容

加载失败,请刷新页面

加载更多

AWK用法入门详解

AWK用法入门详解 简介 awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大。简单来说awk就是把文件逐行的读入,以空格为默认分隔符将...

linjin200
6分钟前
0
0
Centos7 搭建Gitlab服务器并配置项目全过程

一、在Centos7上安装Gitlab 之前尝试过直接yum安装,但服务器从该yum源下载实在太慢,故手动下载rpm包安装。 1.先安装相关依赖 yum -y install policycoreutils openssh-server openssh-clie...

sjcehui2010
26分钟前
1
0
实现基于JWT的Token登录验证功能

前言 放假之前做了几个小项目+课设,都用到了token实现登录验证和权限判断,然鹅当时和同组的小伙伴也都是第一次接触到了token,于是乎都是一脸懵逼(xjbx)的写完了登录验证的前后端逻辑(我...

鱼煎
26分钟前
0
0
数学表达式计算 MathParser.org-mXparser

背景 在系统中需要计算公式,参数可以配置,类似excel的情况,可以实现数据的计算。 mXparser 实例 public static void main(String[] args) throws InterruptedException { Argume...

翱翔fly
32分钟前
2
0
即将开源 | 2亿用户背后的Flutter应用框架Fish Redux

背景 在闲鱼深度使用 Flutter 开发过程中,我们遇到了业务代码耦合严重,代码可维护性糟糕,如入泥泞。对于闲鱼这样的负责业务场景,我们需要一个统一的应用框架来摆脱当下的开发困境,而这也...

阿里云官方博客
40分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部