Flask-WTF擴展可以把處理Web表單的過程變成一種愉悅的體驗。這個擴展對獨立的WTForms包進行了包裝,方便集成到Flask程序中。

  Flask-WTF及其依賴可使用pip安裝:

 pip install flask-wtf

  跨站請求僞造保護

  默認情況下,Flask-WTF能保護所有表單免受跨站請求僞造的攻擊。惡意網站把請求發送到被攻擊者已登錄的其他網站時就會引發CSRF攻擊。

  爲了實現CSRF保護,Flask-WTF需要程序設置一個密匙。Flask-WTF使用這個密匙生成加密令牌,再用令牌驗證請求中表單數據的真僞。設置密匙的方法如下:

 app = Flask(__name__)
app.config['SECRET_KEY'] = 'hard to guess string'

  app.config字典可以用來存儲框架、擴展和程序本身的配置變量。使用標準的字典句發就能把配置值添加到app.config對象中。這個對象還提供了一些方法,可以從文件或環境中導入配置值。

  SECRET_KEY配置變臉是通用密匙,可在Flask和多個第三方擴展中使用,如其名,加密強度取決與變量值的機密程度。不同的程序要使用不同的密匙,而且要保證其他人不知道你所用的字符串。

  爲了增強安全性,密匙不應該直接寫入代碼,而要保存在環境變量中。

  表單類

  使用Flask-WTB時,每個WEB表單都由一個繼承自Form的類表示。這個類定義表單中的一組字段,每個字段都用對象表示。字段對象可附屬一個或多個驗證函數。驗證函數用來驗證用戶提交的輸入值是否符合要求。

 from flask.ext.wtf import  Form
from wtforms import StringField,SubmitField
from wtforms.validators import Required class NameForm(Form):
name = StringField('what is your name?',validators=[Required()])
submit = SubmitField('Submit')

  這個表單中的字段都定義爲類變量,類變量的值是響應字段類型的對象。在這個實例中,NameForm表單中有一個名爲name的文本字段和一個名爲submit的提交按扭。StringField類表示屬性爲type="text"的<input>元素。SubmitField類表示屬性爲type="submit"的<input>元素。字段構造函數的第一個參數是把表單渲染成HTML時使用的標號。

  StringField構造函數中可選參數validators指定一個由驗證函數組成的列表,在接受用戶提交的數據之前驗證數據。驗證函數Required()確保提交的字段不爲空。

  Form基類由Flask-WTF擴展定義,所以從flask.ext.wtf中導入。字段和驗證函數卻可以直接從WTForms包中導入。

  WTForms支持的HTML標準字段如下:
  —————————————————————————————

    StringField       文本字段

    TextAreaField       多行文本字段

    PasswordField      密碼文本字段

    HiddenField     隱藏文本字段

    DateField      文本字段,值爲datatime.date格式

    DateTimeField    文本字段,值爲datatime.datetime格式

    IntegerField     文本字段,值爲整數

    DecimalField    文本字段,值爲decimal.Decimal

    FloatField      文本字段,值爲浮點數

    BooleanField    復選框,值爲True和False  

    RadioField       一組單選框

    SelectField      下拉列表

    SelectMultipleField 下拉列表,可選擇多個值

    FileField      文件上傳字段

    SubmitField        表單提交按扭

    FormField        把表單作爲字段嵌入另一個表單

    FieldList      一組指定類型的字段

  —————————————————————————————

  WTForms內建的驗證函數如下:

  —————————————————————————————

    Email       驗證電子郵件地址

    EqualTo      比較兩個字段的值,常用與要求輸入兩次密碼進行確認的情況

    IPAddress     驗證IPv4網絡地址

    Length        驗證輸入字符串的長度  

    NumberRange   驗證輸入的值在數字範圍內

    Optional        無輸入值時跳過其他驗證函數

    Required       確保字段中有數據

    Regexp      確保正則表達式驗證輸入值

    URL          驗證URL

    AnyOf       確保輸入字在可選值列表

    NoneOf       確保輸入值不在可選值列表

  —————————————————————————————

  把表單渲染成HTML

  表單字段是可調用的,在模板中調用後會渲染成HTML。假設視圖函數把一個NameForm實例通過參數form傳入模板,在模板中可以生成一個簡單的表單,如下:

 <form method="POST">
{{form.hidden_tag()}}
{{form.name.label}} {{form.name()}}
{{form.submit()}}
</form>

  當然這個表單還很簡陋。要想改進表單的外觀,可以把參數傳入渲染字段的函數,傳入的參數會被轉換成字段HTML屬性。例如,可以把字段指定id或class屬性,然後定義CSS樣式:

  <form method="POST">
{{form.hidden_tag()}}
{{form.name.label}} {{form.name(id='my-text-field')}}
{{form.submit()}}
</form>

  

Flask從入門到入土(三)——Web表單的更多相关文章

  1. Flask從入門到入土(三)——模板

    模板是一個包含響應文本的文件,其中包含佔位變量表示的動態部分,其具體值只是請求上下文中才能知道.使用真實值替換變量,再返回最終得到的響應字符串,這一過程稱爲渲染.爲了渲染模板,Flask使用了一個名爲 ...

  2. Flask從入門到入土(二)——請求响应與Flask扩展

    ———————————————————————————————————————————————————————————— 一.程序和請求上下文 Flask從客戶端收到請求時,要讓視圖函數能訪問一些對象 ...

  3. Flask從入門到入土(一)——程序的基本結構

    一.初始化 所有Flask程序都必須創建一個程序實例.Web服務器使用一種名爲Web服務器網關接口的協議,把接收自客戶端的所有請求都轉交給這個對象處理.程序實例書Flask類的對象,創建代碼: fro ...

  4. Flask從入門到入土(四)——登錄實現

    表單介紹 1.表單標籤 聲明表單的範圍,位於表單標籤中的元素將被提交 語法: <form>  </form> 屬性: Method(提交方式get,post) , Enctyp ...

  5. Flask從入門到入土(五)——Flask与数据库

    import sqlite3 def init_db(): sql = 'create table user(id INT,name TEXT)' conn = sqlite3.connect(&qu ...

  6. GOOGLE搜索從入門到精通V4.0

    1,前言2,摘要3,如何使用本文4,Google簡介5,搜索入門6,初階搜索 6.1,搜索結果要求包含兩個及兩個以上關鍵字 6.2,搜索結果要求不包含某些特定資訊 6.3,搜索結果至少包含多個關鍵字中 ...

  7. Flask学习 三 web表单

    web表单 pip install flask-wtf 实现csrf保护 app.config['SECRET_KEY']='hard to guess string' # 可以用来存储框架,扩展,程 ...

  8. Delphi APP 開發入門(三)簡易計算機

    Delphi APP 開發入門(三)簡易計算機 分享: Share on facebookShare on twitterShare on google_plusone_share   閲讀次數:68 ...

  9. Flask 教程 第三章:Web表单

    本文翻译自 The Flask Mega-Tutorial Part III: Web Forms 这是Flask Mega-Tutorial系列的第三部分,我将告诉你如何使用Web表单. 在第二章中 ...

随机推荐

  1. 基于Elasticsearch搜索平台设计

    背景 随着公司业务的高速发展以及数据爆炸式的增长,当前公司各产线都有关于搜索方面的需求,但是以前的搜索服务系统由于架构与业务上的设计,不能很好的满足各个业务线的期望,主要体现下面三个问题: 不能支持对 ...

  2. libev-4.20编译安装及简单使用

    1.源码下载地址: http://www.csdn.net/tag/libev/download 2.库的编译与安装 解压文件,进入文件目录 编译的时候需要首先切换为管理员(root)账户,然后执行以 ...

  3. JMeter之断言 - 响应文本

    1.  响应数据: 2.  添加响应断言: 3.设置响应断言,本例中 设置 响应文本 中 包括 success 字符串的 为真,即通过. 4.如果设置 响应文本 中 包括 error 字符串的 为真, ...

  4. ng机器学习视频笔记(二) ——梯度下降算法解释以及求解θ

    ng机器学习视频笔记(二) --梯度下降算法解释以及求解θ (转载请附上本文链接--linhxx)   一.解释梯度算法 梯度算法公式以及简化的代价函数图,如上图所示. 1)偏导数 由上图可知,在a点 ...

  5. HARBOR 仓库 API功能接口

    1       项目管理 1.1     查看仓库中项目详细信息 curl -u "admin:Harbor12345" -X GET -H "Content-Type: ...

  6. Git 2.0 更改 push default

    近期更新了git,项目push时会提示这样的信息: warning: push.default 尚未设置,它的默认值在 Git 2.0 已从 'matching' 变更为 'simple'.若要不再显 ...

  7. fread和fwrite的使用

    fread和fwrite的使用 fread和fwrite一般用于二进制文件的输入/输出,要不然你打开fwrite写入的文件就是乱码. 1.fread和fwrite函数 数据块I/O fread与fwr ...

  8. DBCP和C3P0使用--未完善

    一.前言: DBCP和C3PO都可以作为数据连接池, 二. 导入jar包: 三.配置applicationContext.xml文件 配置dbcp <!-- 创建数据源 --> <b ...

  9. 浏览器中页面的visibility状态及变化监听

    需求 在浏览器中播放视频,当用户进行页面切换操作时.需要根据视频播放页是否处于可见状态,来控制视频的暂停及重新播放. 相关文档 参考MDN中,关于页面的可见性相关的API说明.https://deve ...

  10. Spring Boot快速入门(最新)

    本章通过完成Spring Boot基础项目的构建并实现一个简单的Http请求处理,让大家对Spring Boot有一个初步的了解,并体验其结构简单.开发快速的特性.预计阅读及演练过程将花费约5分钟. ...