这里介绍一下Flask表单提交相关的方法,还是以代码实例为主。
首先,Flask模板中表单提交代码与我们一般写的H5表单无异,当然,Flask也提供了表单类,Flask-WTF扩展。这里只介绍常规的表单提交方法。
首先是模板类:
处理程序:
当验证成功后,页面显示登录者的名字信息。验证失败则继续显示登录页面。
但以上程序有一个问题,当提交信息后,地址栏显示信息如下:
如果此时点击刷新按钮,那么会出现以下提示:
这不太友好,要解决这个问题可以使用重定向,Flask提供了redirect函数,用法如下:
当我们登录成功后,此时用户刷新页面也没有任何问题,但是名字没有传递到页面。那么这时就要和会话session一块儿使用来保证重定向后信息不被丢失。
用法如下:
我这边用的是python2.7,在直接使用时出现一些错误提示:
the session is unavailable because no secret key was set. Set the secret_key on the application to something unique and secret
提示比较明显,没有设置密钥导致了session不可用,为了安全起见,也应该设置一个密钥,Flask提供了密钥设置的方法:app.config['SECRET_KEY']
设置密钥可以有效防止跨站请求伪造的攻击。
解决办法是在代码中加入:
当然,通常不同的程序使用不同的密钥,并且密钥应该保存在环境变量中,而不是这样直接写。
在进行表单提交操作时,如果我们写错了用户名或者密码,页面往往会给出提示,Flask提供了很方便的操作,即使用Flash消息。
这里做一个简单的用户不存在提示(只是演示Flash用法,用户名密码分开提示是不安全的)
页面模板中消息提示的代码:
现在应该是可以了,这里我本人使用的是python2.7,如果消息提示为中文,可能此时会遇到一个编码错误,信息:
UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 0: ordinal not in range(128)
原因是读取消息时,python的str默认是ascii编码,和unicode编码冲突,解决方案是加入如下代码:
大功告成!
领取专属 10元无门槛券
私享最新 技术干货