Flask表單(Flask-WTF)

来源:http://www.cnblogs.com/wongbingming/archive/2017/04/28/6781770.html
-Advertisement-
Play Games

1、request.from獲取POST表單數據 # hello.py # form.html # home.html #signin-ok.html 2、使用Flask-WTF擴展 # hello.py # index.py 附:共同的基模板 # base.html ...


1、request.from獲取POST表單數據

# hello.py

 1 #coding:utf-8
 2 
 3 from flask import Flask,request,render_template
 4 
 5 app = Flask(__name__)
 6 
 7 @app.route('/',methods=['GET']) #methods是一個列表
 8 def home():
 9     return render_template('home.html')
10 
11 @app.route('/signin',methods=['GET'])
12 def signin_form():
13     return render_template('form.html')
14 
15 @app.route('/signin',methods=['POST'])
16 def signin():
17     username = request.form['username']
18     password = request.form['password']
19     if username == 'admin' and password == 'password':
20         return render_template('signin-ok.html',username=username)
21     else:
22         return render_template('form.html',message='用戶名或者密碼錯誤,請重新登陸>>',username=username)
23 
24 
25 if __name__ == '__main__':
26     app.run()

# form.html

 1 <!DOCTYPE html>
 2 <html>
 3     <meta charset="utf-8">
 4     <head>
 5         <title>登陸界面</title>
 6     </head>
 7     <body>
 8         {% if message %}
 9             <p style="color:red">{{ message }}</p>
10         {% endif %}
11         <form action='/signin' method="post">
12             <legend>請登陸您的賬號:</legend>
13             <input type="text" name="username" placeholder='Username' value="{{ username }}"><br>
14             <input type="password" name="password" placeholder="Password" value="{{ password }}"><br>
15             <button type="submit">登陸</button> 
16         </form> 
17     </body>
18 </html>

 

# home.html

 1 <!DOCTYPE html>
 2 <html>
 3     <meta charset="utf-8">
 4     <head>
 5         <title>主頁</title>
 6     </head>
 7     <body>
 8         <h1>你好,歡迎來到首頁</h1>
 9         <p><a href="/signin">點擊登陸</a></p>
10     </body>
11 </html>

#signin-ok.html

 1 <!DOCTYPE html>
 2 <html>
 3     <meta charset="utf-8">
 4     <head>
 5         <title>登陸成功</title>
 6     </head>
 7     <body>
 8         <h1>歡迎你,{{ username }}</h1>
 9     </body>
10 </html>

2、使用Flask-WTF擴展

# hello.py

 1 #coding:utf-8
 2 
 3 from flask import Flask,render_template
 4 from flask.ext.bootstrap import Bootstrap
 5 from flask.ext.wtf import Form
 6 from wtforms import StringField,SubmitField
 7 from wtforms.validators import Required
 8 
 9 app = Flask(__name__)
10 app.config['SECRET_KEY']='hard to guess string'
11 bootstrap = Bootstrap(app)
12 
13 
14 class NameForm(Form):
15     name = StringField('what is your name?',validators=[Required()])
16     submit = SubmitField('Submit')
17 
18 @app.route('/',methods=['GET','POST'])
19 def index():
20     name = None
21     form = NameForm()
22     if form.validate_on_submit():
23         name = form.name.data #沒有這一步,submit後name=None
24         form.name.data = ''   #沒有這一步,submit後文字框還會遺留上一次輸入的文字
25     return render_template('index.html',form=form,name=name)
26 
27 if __name__ == '__main__':
28     app.run()

# index.py

 1 {% extends "base.html" %}  
 2 {% import "bootstrap/wtf.html" as wtf %}  
 3   
 4 {% block title %}Flasky{% endblock %}  
 5   
 6 {% block page_content %}  
 7 <div class="page-header">  
 8     <h1>Hello, {% if name %}{{ name }}{% else %}Stranger{% endif %}!</h1>  
 9 </div>  
10 <!-- 導入wtf.html渲染整個Flsk-WTF表單,參數form是hello.py中傳過來的form實例-->  
11 {{ wtf.quick_form(form) }}  
12 {% endblock %} 

附:共同的基模板

# base.html

 1 {% extends "bootstrap/base.html" %}
 2 {% block title %}Flasky{% endblock %}
 3 
 4 {% block navbar %}
 5 <div class="navbar navbar-inverse" role="navigation">
 6 <div class="container">
 7     <div class="navbar-header">
 8         <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
 9             <span class="sr-only">Toggle navigation</span>
10             <span class="icon-bar"></span>
11             <span class="icon-bar"></span>
12             <span class="icon-bar"></span>
13         </button>
14         <a class="navbar-brand" href="/">Flasky</a>
15 
16     </div>
17     <div class="navbar-collapse collapse">
18         <ul class="nav navbar-nav">
19             <li><a href="/">Home</a></li>
20             <li><a href="/">Twitter</a></li>
21             <li><a href="/">Blog</a></li>
22         </ul>
23     </div>
24 </div>
25 </div>
26 {% endblock %}
27 
28 
29 {% block content %}
30 <div class="container">
31     <div class="page-header">
32         {% block page_content %}{% endblock %}
33     </div>
34 </div>
35 
36 {% endblock %}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Hibernate的二級緩存 理解緩存定義: 緩存(Cache):電腦領域非常通用的概念。它介於應用程式和永久性數據存儲源(如硬碟上的文件或者資料庫)之間,其作用是降低應用程式直接讀寫永久性數據存儲源的頻率,從而提高應用的運行性能。緩存中的數據是數據存儲源中數據的拷貝。緩存的物理介質通常是記憶體。 ...
  • 使用 RegexString.with(string).pattern(pattern).start() + 後續操作(matches,find或者是replace) 源碼 示例 ...
  • 經過了一段時間的學習,慢慢的計入到了python的列表、元組的學習了,這一部分是後面函數的基礎,這也是無論何種語言都要學習的部分。其實過程很辛苦,不過對於小白的我不見得是一件壞事,反正都看不懂,倒也沒有什麼心理負擔。想想學成後的一覽眾山小,此時的積累,便是每一步都要堅實的。 列表、元組 列表是我們最 ...
  • 函數, get()與setdefault(), lambda表達式,三元運算, 遍歷list與dict的方法. ...
  • 對編程語言比較熟悉的朋友,應該知道“反射”這個機制。Python作為一門動態語言,當然不會缺少這一重要功能。然而,在網路上卻很少見到有詳細或者深刻的剖析論文。下麵結合一個web路由的實例來闡述python的反射機制的使用場景和核心本質。 一、前言 在上面的代碼中,我們必須區分兩個概念,f1和“f1" ...
  • 讀這本書,前後算作一次半吧。第一次讀時,到了第八課的形態學處理部分時荒棄了,當時也沒有養成做筆記的習慣,導致最後不了了之。後來在去年12月份左右重新撿起這本書,並且堅持在閱讀的同時多看源碼多做筆記,最終於4月底完成閱讀與學習。 目前我對這本書的看法是,著重介紹灰度圖像處理的基礎知識,包括基本的bmp ...
  • 1.為項目添加POI POI官網鏈接 點進去之後下載(上邊的是編譯好的類,下邊的是源代碼) 解壓文件夾,把下麵三個文件複製到WebComtent>WEB-INF>lib文件夾下 再把這三個文件複製到Tomcat的lib文件夾下,否則Tomcat會因為找不到類而報錯(這個地方鬱悶了一上午) 讀取“.x ...
  • hasattr(object, name) 本函數是用來判斷對象object的屬性(name表示)是否存在。如果屬性(name表示)存在,則返回True,否則返回False。參數object是一個對象,參數name是一個屬性的字元串表示。 輸出結果: getattr(object, name[,de ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...