WTForms校验框架一个经典的总结(两个校验属性相互依赖的情况不建议放一起校验)
时间:2019-02-11
本文章向大家介绍WTForms校验框架一个经典的总结(两个校验属性相互依赖的情况不建议放一起校验),主要包括WTForms校验框架一个经典的总结(两个校验属性相互依赖的情况不建议放一起校验)使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
核心原理就是:两个不同的属性相互依赖时,不适合放在一个WTForms去校验【比如:password 依赖 email】
from werkzeug.security import check_password_hash
from kirin_app.db_models.table_user import User
from wtforms import Form,StringField,PasswordField,ValidationError,validators
class LoginForm(Form):
email = StringField("email", validators=[validators.Email("邮件格式错误,请重新输入...")])
password = PasswordField("password", validators=[validators.Length(min=6, max=16, message="密码长度必须为6-16位")])
def validate_email(self, field):
if not User.query.filter_by(email=field.data).first():
raise ValidationError("邮箱不存在!!!")
# 这种password校验依赖的情况,就不适合放这里校验,适合放入数据库模型中校验!
# WTForms校验属性的顺序是随机的,如果先校验的是password,那么no_email就无法获取!
# def validate_password(self, field):
# user = User.query.filter_by(email=no_email).first()
# return check_password_hash(self.__password,field.data)
#这段代码放入数据库模型的User中去校验
def check_password(self, new_password):
user = User.query.filter_by(email=self.email).first()
# 新传入的密码必须哈希加密才能和数据库的比较!!!
return check_password_hash(user.password,new_password)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法