flask 后台表单验证模块

时间:2022-09-01 15:01:15

我不想直接用flask的wtf模块,太大,功能太多,用不了。但后台也不能不做验证吧,我比较懒,不想一行一行写代码验证,所以就写了一个验证模块,对于小项目也够用了

# encoding=utf-8

# 这是一个简单的后台验证框架,因为前台的话要用ajax处理,那么后台就不需要复杂的表单处理了

# 基础表单类,具体验证表单继承它
from flask import session class BaseForm(object):
def __init__(self,form=None): self.form = form
self.fields = []
self.errors = [] # 错误信息存放的地方
self.init() def init(self):
if not self.form:
return False # 给表单赋值
for field_name in dir(self):
field = self.__getattribute__(field_name)
if isinstance(field,Field):
if field_name in self.form:
field.data = self.form[field_name]
self.fields.append((field_name,field.validate)) # 验证自定义的以validate_开头的方法
for validate_method in dir(self):
if validate_method.startswith('validate_'):
self.fields.append((validate_method,self.__getattribute__(validate_method))) # 验证入口
def validate(self):
status = True
for field_name,validate_method in self.fields:
status = validate_method() and status
if not status:
print field_name,status
return False
return status # 字段类,主要提供字段的各种验证和约束
class Field(object):
def __init__(self,label=None,type='text',validators={},description=None,data=''):
self.data = data
self.label = label
self.type = type
self.validators = validators
self.description = description # 验证入口,验证该字段所有的约束条件
def validate(self):
status = True
for method_name,param in self.validators.items():
status = self.__getattribute__(method_name)(param) and status
if not status:
print method_name,status
return True
return status # 验证数据是否复合正则表达式
def __rule(self,re_str):
import re pattern = re.compile(re_str)
match = pattern.match(self.data)
if match:
return True
return False # 对开提供的正则表达式模块
def regex(self,re_str):
return self.__rule(re_str) # 是否为数字
def digits(self,status=True):
return self.__rule(r"\d+") # 是否是链接
def url(self,status=True):
re_str = r"^(https?|s?ftp):\/\/(((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(#((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$"
return self.__rule(re_str) # 是否是邮箱
def email(self,status=True):
re_str = r"^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$"
return self.__rule(re_str) # 是否为空
def not_null(self,status):
if not status:
return True
if not self.data:
return False
if hasattr(self.data,'replace') and len(self.data.replace(' ','')) < 0:
return False
if len(self.data) == 0:
return False
return True # 最小长度
def min_length(self,min=-1):
return self.not_null(True) and len(self.data) >= min # 长度范围
def length_range(self,range=[]):
if self.not_null(True) and len(range) == 2:
data_length = len(self.data)
return data_length >= range[0] and data_length <= range[1]
return False # 最大长度
def max_length(self,max):
return self.not_null(True) and len(self.data) <= max # 最小值
def min(self,min):
try:
return int(self.data) >= min
except Exception,e:
print e
return False # 最大值
def max(self,max):
try:
return int(self.data) <= max
except Exception,e:
print e
return False # 值范围
def data_range(self,range=[]):
try:
data = int(self.data)
if len(range) == 2:
return data >= range[0] and data <= range[1]
return False
except Exception,e:
print e
return False # 是否等于field
def equal_to(self,field):
return self.data == field.data # 是否为规定的值
def choices(self,args=[]):
return self.data in args # 检查多选框
def checked(self,status=True):
if not status:
return True
return self.data in [1,'y','yes','true']

flask 后台表单验证模块的更多相关文章

  1. python运维开发&lpar;十九&rpar;----Django后台表单验证、session、cookie、model操作

    内容目录: Django后台表单验证 CSRF加密传输 session.cookie model数据库操作 Django后台Form表单验证 Django中Form一般有2种功能: 1.用于做用户提交 ...

  2. java后台表单验证工具类

    /** * 描述 java后台表单验证工具类 * * @ClassName ValidationUtil * @Author wzf * @DATE 2018/10/27 15:21 * @VerSi ...

  3. flask之表单验证 2018&period;12&period;23

    #flask的消息闪现依赖于flash库,用户发送的请求方式存储在request模块中 #跳转依赖于redirect模块,还可以通过url_for方法来进行方法上的寻址 from flask impo ...

  4. flask提交表单验证不通过,以及CSRF攻击原理

    学习表单的问题1. 提交表单时怎么都无法验证通过 记录一下,自己的学习bug,主要是因为在模板中书写渲染的语句时,把CSRF的字段名写错了. 因为在模板中书写一些语句是没有提示的,自己手动敲代码容易出 ...

  5. flask form表单验证

    新建forms.py文件 #!/usr/bin/env python #-*-coding:utf--*- #导入模块 from flask_wtf import FlaskForm #FlaskFo ...

  6. flask web 表单验证 WTForms

    简介 WTForms 是一个flask集成框架,或者说是库,用于处理浏览器表单提交的数据,它在flask-WTF的基础上扩展并添加了一些随手可得的精巧帮助函数,这些函数将会是在flask里使用表单更加 ...

  7. Flask wtforms 表单验证使用

    目录 wtforms 使用1(简单版): 使用2(复杂版): wtforms 安装:pip3 install wtforms 使用1(简单版): from flask import Flask, re ...

  8. 第三百一十一节,Django框架,Form表单验证

    第三百一十一节,Django框架,Form表单验证 表单提交 html <!DOCTYPE html> <html lang="en"> <head& ...

  9. 九 Django框架,Form表单验证

    表单提交 html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quot ...

随机推荐

  1. JQuery学习&lpar;选择器-基本-&ast;&rpar;

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"% ...

  2. &lbrack;转&rsqb;C&num; WinForm treeview checkbox----递归算法利用

    在平常开发中,treeview的节点显示checkbox,若节点存在几级时,往往希望,选中父节点后,其子节点都要选中,如何实现勒,请看 using System; using System.Colle ...

  3. 合理利用 vs2013的性能分析跟诊断

    选择对应的项目==> 我正常是选择采样 就包括里面的一些耗时.  挺好用的. 可以根据热路径 还有访问的占比.知道哪个环节占用的访问时间 还有性能耗能多. 可以点进去 跟踪跟修改

  4. 博弈论入门小结 分类: ACM TYPE 2014-08-31 10&colon;15 73人阅读 评论&lpar;0&rpar; 收藏

    文章原地址:http://blog.csdn.net/zhangxiang0125/article/details/6174639 博弈论:是二人或多人在平等的对局中各自利用对方的策略变换自己的对抗策 ...

  5. JMeter 监控和记录&amp&semi;常用功能

    使用https连接时,如果对应站点的CA 证书错误,会直接报连接不到服务器的错误,org.apache.commons.httpclient.NoHttpResponseException,把错误证书 ...

  6. 瞎j8封装第二版之数据库连接池

    写得很蛋疼,本来想支持多线程的,奈何对多线程和连接池理解着实太菜: 所以,起码是能拿到连接了... 但是还是不太懂这个连接池 我也是半抄别人的,以后再搞一搞这个吧. 先是配置文件 理想是很丰满的,奈何 ...

  7. 如何实现 C&sol;C&plus;&plus; 与 Python 的通信?

    属于混合编程的问题.较全面的介绍一下,不仅限于题主提出的问题.以下讨论中,Python指它的标准实现,即CPython(虽然不是很严格) 本文分4个部分 1. C/C++ 调用 Python (基础篇 ...

  8. c&num; 传入c&plus;&plus;dll 回调函数输出byte 导致 bug

  9. 为什么setinterval和settimeout越点击越快以及响应的解决办法

    setinterval大家都很了解,但是如果时间长的话,误差也会越来越大,所以我习惯上使用settimeout的递归,闲来没事,写了一个定时器的递归 <!DOCTYPE html> &lt ...

  10. 压缩JS时生成source&lowbar;map

    @echo off :: 当前目录 src/test set currDir=src/test/ set sourceMapFileName=test.js.map set inputList=%in ...