Flask:web表单
客户端发送的所有通过POST发出的请求信息都可以通过request.form获取.但是如果我们要生成表单的HTML代码和验证提交的表单数据那么就需要采用另外的方法.Flask-WTF扩展可以把处理web表单的过程变得更简单.
Flask-WTF能保护所有表单免受CSRF的攻击.至于CSRF的原理参考http://www.cnblogs.com/zhanghongfeng/p/7787499.html这个帖子.为了实现CSTF保护,Flask_WTF需要程序设置一个密钥.Flask-WTF用这个密钥生成加密令牌,在用令牌验证请求中表单数据的真伪.设置密钥的方法如下:
import os
app.config['SECRET_KEY']=os.urandom(20)
下面我们来看下表单类.首先来看下完整的代码:
from flask_wtf import Form,FlaskForm
from wtforms import StringField,SubmitField
from wtforms.validators import Required
class NameForm(FlaskForm):
name=StringField('what is your name?',validators=[Required()])
submit=SubmitField('Submit')
@app.route('/',methods=['GET','POST'])
def hello_world():
name=None
form=NameForm()
if form.validate_on_submit():
name=form.name.data
form.name.data=''
return render_template('index1.html',form=form,name=name)
index1的HTML代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>flask test</title>
</head>
<body>
{{ name }}
<form method="POST">
{{ form.hidden_tag() }}
{{ form.name.label }}{{ form.name(id='my-text-field') }}
{{ form.submit() }}
</form>
</body>
</html>
当我们访问http://192.168.0.12:8000/的时候,网页显示如下
当我们在输入框中输入信息则显示出我们输入的信息
接下来我们就来看下代码是如何运行的.首先我们定义了一个表单类,每个表单类都继承自
FlaskForm.这个表单类中包含一个文本字段和一个提交按钮.
WTForms中支持的HTML标准字段如下
字段类型 说 明
StringField 文本字段
TextAreaField 多行文本字段
PasswordField 密码文本字段
HiddenField 隐藏文本字段
DateField 文本字段,值为 datetime.date 格式
DateTimeField 文本字段,值为 datetime.datetime 格式
IntegerField 文本字段,值为整数
DecimalField 文本字段,值为 decimal.Decimal
FloatField 文本字段,值为浮点数
BooleanField 复选框,值为 True 和 False
RadioField 一组单选框
SelectField 下拉列表
SelectMultipleField 下拉列表,可选择多个值
FileField 文件上传字段
SubmitField 表单提交按钮
FormField 把表单作为字段嵌入另一个表单
FieldList 一组指定类型的字段
再来看下视图函数.app.route修饰器中添加的methods参数告诉Flask在URL映射中把这个视图函数注册为GET和POST请求的处理程序,否则没有methods参数,将只把视图函数注册为GET请求的处理程序.
用户第一次访问程序的时候,服务器会收到一个没有表单数据的GET请求.所以validate_on_submit将返回Flase.通过渲染模板处理请求,用户会看到浏览器中显示一个表单
用户提交表单后,服务器收到一个包含数据的POST请求,valide_on_submit()会调用name字段上附属的Required函数,如果名字不为空,就能通过验证.valide_on_submit返回True.并将名字赋值给局部变量name.最终在页面上被渲染出来
重定向和用户会话
前面的这个表单程序,当我们输入了用户名并且再一次刷新index的页面的时候,之前的信息已经不存在,又回到了表单提交的页面.也就说之前的用户会话没有保存下来,所以刷新后找不到之前的用户.那么要保存用户会话就要用到之前介绍的session会话
代码修改如下:
from flask import Flask,render_template,session,redirect,url_for
@app.route('/',methods=['GET','POST'])
def hello_world():
form=NameForm()
if form.validate_on_submit():
session['name']=form.name.data
return redirect(url_for('hello_world'))
print session.get('name')
return render_template('index1.html',form=form,name=session.get('name'))
首先将name的值赋值给session[‘name’] 然后进行重定向.这里重定向使用的是redirect函数,这里重定向使用的是redirect(url_for('hello_world')).url_for(‘hello_world’)将生成对应的URL也就是’/’.这种使用方式的好处是保证URL和定义的路由兼容.url_for函数的第一个必须指定的参数名是端点名,即路由的内部名字.默认情况下,路由的端点是相应视图函数的名字,比如这里传入的是hello_world函数名
当然也可以简单点通过redirect(‘/’)的方式直接指定URL.
最新文章
- Openxml入门---Openxm读取Excel数据
- Todd&#39;s Matlab讲义第5讲:二分法和找根
- Spring与JPA
- linq to entity中遇到的问题
- Keepalived安装配置
- 解决Fiddler无法抓到手机的会话包
- 解决python version 2.7 required,which was not find in the registry
- 【POJ1005】I Think I Need a Houseboat
- jsp中九大内置对象
- UNIX环境高级编程——IPC总结
- flask websocker
- pillow的用法
- 反向代理&;集线器和交换机的区别&;广播地址&;seq与ack的区别
- Linux chpasswd (批量或单一修改用户密码)和passwd(直接修改用户密码)
- 如何用istio实现请求超时管理
- Java8新特性 集合的stream的map
- [py][mx]django分页第三方模块django-pure-pagination
- JS ——DOM,BOM(包含盒模型,动画)总结
- 28 Data Race Detector 数据种类探测器:数据种类探测器手册
- Office 卸载问题(安装包的语言不受系统支持)
热门文章
- AbstractFactory
- WebApp 安全风险与防护课堂开课了!
- [BUG] CS0234: 命名空间“System.Web.Mvc”中不存在类型或命名空间名称“Ajax”(是否缺少程序集引用?)
- iis无法启动的解决办法-卸掉KB939373补丁
- dedecms调用新闻文章列表
- ThinkPHP示例:CURD
- 2016.6.20 maven下载与安装步骤
- 25. Spring Boot使用自定义的properties【从零开始学Spring Boot】
- Timus : 1002. Phone Numbers 题解
- 启动Nginx目录浏览功能及 让用户通过用户名密码认证访问web站点