Flask学习日志(十) - Flask入门 表单

每日壁纸.jpg

文 / 秦未

今天学习Flask的表单处理,我们需要一个插件:flask-wtf

Flask-WTF 提供了简单的 WTForms 集成。

特性:

  • 与 WTForms 的集成。
  • 带有 CSRF 令牌的安全表单。
  • 全局的 CSRF 保护。
  • ecaptcha 支持。
  • 支持 Flask-Uploads 的文件上传。
  • 国际化集成。

下载安装:

pip install flask-wtf

我们这样理解flask生成的表单,定义它,其实就是定义一个类,然后通过flask-wtf的处理渲染,传到模板中。

所以我们建立一个forms.py文件,内容如下:

# /app/forms.py
# -*- coding:utf-8 -*-

from flask.ext.wtf import Form
from wtforms import StringField, PasswordField, SubmitField
from wtforms.validators import DataRequired


class LoginForm(Form):
    username = StringField(label=u'账号', validators=[DataRequired()])
    password = PasswordField(label=u'密码', validators=[DataRequired()])
    submit = SubmitField(label=u'提交')


解释:我们定义一个LoginForm类,它继承了Form,我们在其中定义了3个字段,字符串类型(前端就是text),密码类型,提交类型,label为标签(即别名),validators属于验证,DataRequired其中的Required懂前端的都应该知道,它是input标签中要求字段必填的选项。

然后我们修改app.py中的login函数:

@app.route('/login/', methods=['GET', 'POST'])
def login():
    # 判断请求方式
    # if request.method == 'POST':
    #     # POST方式时数据是在form里面
    #     username = request.form.get('username')
    #     password = request.form.get('password')
    #     # 获取文件
    #     my_file = request.files.get('file')
    #     # 获取当前路径
    #     basepath = path.abspath(path.dirname(__file__))
    #     # 将路径连接
    #     upload_path = path.join(basepath, 'static/uploads/')
    #     # 保存文件并将文件名获取封装
    #     my_file.save(upload_path + secure_filename(my_file.filename))
    #     # 跳转upload函数
    #     return redirect(url_for('upload'))
    # else:
    #     # GET方式时数据是在args里面
    #     username = request.args.get('username')
    #     password = request.args.get('password')
    # return render_template('blog/login.html', method='GET')
    from forms import LoginForm
    form = LoginForm()
    return render_template('blog/login.html', form=form)

login.html修改为:

{% extends 'blog/base.html' %}
{% block name %}
<h1>表单</h1>
<form action="{{ url_for('.login') }}" method="post" enctype="multipart/form-data">
    {{ form.username.label }}
    {{ form.username() }}
    {{ form.password.label }}
    {{ form.password() }}
    {{ form.submit() }}

</form>

{% endblock %}

我觉得代码都很好明白吧!LoginForm()为实例化,传给login.html,form使用就是点点点。

当然你现在可以运行一下,你会发现报错:

KeyError: 'A secret key is required to use CSRF.'

此类框架在处理表单时都会有一个机制是为了防止CSRF攻击的,详细说明请看:浅谈CSRF攻击方式 - hyddd - 博客园

这个机制其实就是在表单提交的过程中加一个随机字符串,只有当客户端和服务器的随机字符串一致,后端才执行,看似简单的一个机制却有效防止了CSRF攻击。

所以:

我们建立一个config文件,内容:

SECRET_KEY = 'hard to guess string'

hard to guess string的意思是:很难猜到的字符串,随便你写了。

然后在app.py里面增加一条代码:

app.config.from_pyfile('config')

在manager = Manager(app)之前一行加即可,再次运行,你会发现:

运行状态.png

详细文档请查阅:Flask-WTF 0.9.3 文档

官方并没有提供多少种数据类型的查询,这里有一张图统计了一下:

数据类型.png

本来这里是讲引用Bootstrap样式的内容的,但是我又不想使用它,所以就略过。

---end---

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容