原生表单
HTML部分
raw_form.html
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>Title</title></head><body><form action="" method="post"><label >用户名</label><input type="text" name="username"><br><label >密码</label><input type="password" name="password" ><br><input type="submit" value="注册" /></form></body></html>
视图函数部分
hello.py
from flask import Flask, render_template, requestapp = Flask(__name__)@app.route("/", methods=["GET", "POST"])def index():if request.method == "POST":username = request.form.get('username')password = request.form.get('password')return render_template("raw_form.html", username=username)return render_template('raw_form.html')if __name__ == "__main__":app.run(debug=True)
flask-wtf
简介|安装包
优点
- 可以抵制CSRF跨站请求伪造的攻击,更具安全性
- 减少重复编写表单HTML
- 提供丰富的表单校验方法
使用
定义表单
# 1、配置密匙from flask import Flaskapp = Flask(__name__)app.config['SECRET_KEY'] = 'XXXX'# 2、导包使用from flask_wtf import FlaskForm #web表单都从该类继承from wtforms import StringField, SubmitField #字段from wtforms.validators import DataRequired #字段校验#定义表单类class NameForm(FlaskForm):name = StringField('Name:' validators=[DataRequired()]) #第一个参数将函数构造成label;可以多个校验同时生效,所以为list类型submit = SubmitField('submit')
视图函数
#...同上@app.route("/", methods=['GET', 'POST'])def index():form = NameForm()return render_template('index.html', form=form)
获取表单值
# 表单对象获取name = form.name.data# request 对象获取name = request.form.get("name")
form对象渲染表单
<form method='POST'>{{ form.hidden_tag() }} # 生成一个隐藏字段,供Flask-WTF的CSRF机制使用{{ form.name.label }} {{ form.name(id='test') }} # 渲染name字段并为其添加属性{{ form.submit() }}</form>
flask-bootstrap渲染表单
# 需要在原视图函数中注册Bootstrap ,否则在渲染时候报错找不到bootstrap/wtf.htmlform flask_bootstrap import Bootstrapbootstrap = Bootstrap(app)
单字段渲染
{% import 'bootstrap/wtf.html' as wtf %}{{ wtf.form_field(form.name, class="form-control text-body") }}
快速渲染
{% import 'bootstrap/wtf.html' as wtf %}{{ wtf.quick_form(form) }}
WTForms支持的HTML标准字段
| 字段类型 | 说明 | eg | | —- | —- | —- | | StringField | 文本字段 | | | TextAreaField | 多行文本字段 | | | PasswordField | 密码文本字段 | | | HiddenField | 隐藏文本字段 | | | DateField | 文本字段,值为datatime.date格式 | | | DateTimeField | 文本字段,值为datatime.datetime格式 | | | IntegerField | 文本字段,值为整数 | | | DecimalField | 文本字段,值为 decimal.Decimal | | | FloatField | 文本字段,值为浮点数 | | | BooleanField | 复选框,值为 True 和 False | | | RadioField | 一组单选框 | | | SelectField | 下拉列表 | SelectField(label=”请选择环境”, choices=[(1, “无锡”), (7, “HK”), (4, “AWSCA”)], default=1, coerce=int) | | SelectMultipleField | 下拉列表,可选择多个值 | | | FileField | 文件上传字段 | | | SubmitField | 表单提交按钮 | | | FormField | 把表单作为字段嵌入另一个表单 | | | FieldList | 一组指定类型的字段 | |
WTForms支持的验证函数
| 方法名 | 说明 |
|---|---|
| DataRequired | 确保转换类型后字段中有数据 |
| InputRequired | 确保转换类型前字段中有数据 |
| 验证电子邮件地址 | |
| EqualTo | 比较两个字段的值;常用于要求输入两次密码进行确认的情况 |
| IPAddress | 验证 IPv4 网络地址 |
| Length | 验证输入字符串的长度 |
| MacAddress | 验证Mac地址 |
| UUID | 验证UUID |
| NumberRange | 验证输入的值在数字范围内 |
| Optional | 无输入值时跳过其他验证函数 |
| Regexp | 使用正则表达式验证输入值 |
| URL | 验证 URL |
| AnyOf | 确保输入值在可选值列表中 |
| NoneOf | 确保输入值不在可选值列表中 |
拓展
表单中添加图标
.user-icon {padding-left:30px;background-repeat: no-repeat;background-position-x: 4px;background-position-y: 4px;background-image:url();}
然后在模板里渲染时传入这个类:
<form method="POST">{{ form.hidden_tag() }}{{ wtf.form_field(form.username, class="form-control user-icon") }}{{ wtf.form_field(form.password) }}{{ wtf.form_field(form.submit) }}</form>
