基於flask的web應用的誕生
Flask是一個非常優秀的web框架,它最大的特點就是保持一個簡單而易於擴展的小核心,其他的都有用戶自己掌握,並且方便替換,甚至,你可以在社區看到眾多開源的,可直接用於生產環境下的擴展。到目前為止,我相信關於他的介紹以及非常的多,就算cnblog中,隨便一搜也會有很多內容,但還是拋磚引玉,就當是一個自我的總結
部署環境
安裝python
首先,當然是安裝python環境,去官網來下載最新的環境(我選擇最新的3.6版本)
然后一路下一步即可,注意記錄或選擇一下安裝路徑。
環境變量
接下來配置環境變量與java幾乎一樣,path后;.;輸入python的安裝路徑,然后再次;,;輸入python目錄下的Scripts文件夾,已使用py自帶的一些工具(如pip)
安裝flask
配置完成pip后,安裝flask就很簡單了,輸入cmd進入控制台,然后輸入如下命令即可:
pip3.6 install flask
開發工具
工欲善其事必先利其器,開發工具的選擇很重要,我選擇的是pycharm,也可從官網下載,以及請大家使ji用huo正fang版shi
開始開發
首先,打開pycharm,創建一個Pure Python項目:
項目創建好之后,有的也僅僅是一個空項目,還有創建一個py文件已進行開發,在項目文件夾下右鍵new-->python file 然后取一個名字,我取得名字為default,將在目錄文件夾下創建default.py文件。
flask初探
在此文件上輸入代碼(假設安裝flask已經成功):
from flask import Flask #導入Flask類
app=Flask(__name__) #創建Flask類的一個實例
if __name__=='__main__': #Python入口程序
app.run(debug=True) #使其運行於本地服務器上
這是可將cmd控制台的目錄切換至項目目錄,輸入命令:
python default.py
導入Flask類后,運行腳本時會自動創建WSGI程序
如圖顯示即為正確:
根據提示,此時在瀏覽器中輸入flask的默認地址,顯示如下:
因為現在還沒有任何頁面,所有訪問任何地址均為404
說明
debug=true代表運行在調試模式,調試模式絕對不能用於生產環境!!!
路由
下面為此應用創建一個默認路由,flask使用裝飾器為路由配置:
@app.route("/")
def index():
return "<h1>hello world</h1>"
此時訪問,頁面如下:
輸出return的內容,而此時的控制台顯示:
狀態碼為200,不再為404
這里的裝飾器暫時可以理解為java中的注解,以后再詳細討論,同時這種路由的使用方式也可以暫時理解為j2ee中servlet的注解式路由方式。
帶參路由
同時flask也支持帶參路由:
@app.route("/user/<name>")
def user(name):
return "<h1>hell %s</h1>"%name
在瀏覽器中輸入:
http://127.0.0.1:5000/user/niufen
此時輸入為:
關於路由暫時先說這么多,然后進入cmd控制台,ctrl+c退出服務器,輸入python,進入python命令行界面,此時可以執行各種py語句
然后在此界面導入default.py對象下的app對象:
from default import app
然后回車,此時可以在命令行中使用app對象,輸入:
app.url_map
我的顯示如下:
可以看到,使用一個map存儲了此對象下的所有路由,並從內容可以看到 全是get方式,注意其中的static,是存放的靜態文件,如圖片,順便提一下,這也體現了flask的一個特點,即它有眾多的配置選項,但基本上都在初始狀態下有個明確的默認值,比如模板在templates中,圖片在static中,雖然這個配置可以修改,但不建議這么做,尤其是剛開始的時候。
from default import app這行代碼代表了從default對象中導入app,並在之下可以直接使用app,同樣的還有之前的代碼 from flask import Flask
python中有兩種導入方式,import直接導入和from ... import導入,具體區別可查看py基本語法
如果想讓路由為post方式,也很簡單:
@app.route("/user",methods=["POST"])
def user():
name=request.args.get("name")
return "<h1>hell %s</h1>"%name
即可
請求上下文
flask還有請求上下文對象,即request,如:
from flask import request #頁頭 導入request對象
@app.route(/req_test)
def req_test():
val=""
for key,value in request.args.items():
val+=" %s = %s <br>"%(key,value)
return val;
在控制台輸入exit()后,繼續輸入python default.py進入服務器
此時在瀏覽器中輸入url:
http://127.0.0.1:5000/req_test?age=5&name=abc
此時瀏覽器中顯示為:
測試代碼2(假設已導入request對象):
@app.route(/req_test)
def req_test():
val=""
for key,value in request.headers.items():
val+=" %s = %s <br>"%(key,value)
return val;
瀏覽器顯示為:
flask自帶系統上下文共計四個:
current_app 約等於application
g 一個用於臨時存儲的對象 約等於viewbag
request 與servlet或asp.net中含義大體相同
session 與servlet或asp.net中含義大體相同
響應
flask響應可以使用make_response對象,用法與java servlet中的用法類似:
from flask import make_response #頁頭,導入make_response對象
@app.route("/res_test")
def res_test():
response=make_response("<h1>hello world</h1")
response.set_cookie("name","niufennan")
return response;
此代碼的內容為在響應的時候設置cookie
在瀏覽器中輸入地址:
http://127.0.0.1:5000/res_test
在頁面中顯示為黑體hello world,但是可以查看瀏覽器,發現響應內容已經存入瀏覽器的cookie中 如圖:
其他常用功能:跳轉
在web開發中,經常會遇到直接跳轉的情況,flask中也提供了redirect方法來實現:
from flask import redirect # 頁頭,導入redirect對象
@app.route("/")
def index():
return redirect("https://www.baidu.com/")
此時訪問將直接跳轉至百度
其他常用功能:響應碼
普通響應碼可直接在return的返回字符串后使用,如:
@app.route("/")
def index():
return "<h1>hello world</h1>",400
訪問結果如下:
可以看到,雖然此時頁面顯示內容不變,但是響應碼為400
錯誤碼flask也提供了一個專有的函數:
from flask import abort #導入abort對象
@app.route('/user/<name>')
def user(name):
if name =='test':
abort(500)
return "<h1>hello %s!</h1>"%name
此代碼的功能是當name的值為test是,返回錯誤碼為500,注意此時頁面不會顯示內容,因為此時程序不由代碼控制,而將控制權交給了系統。
至此,flask基礎知識已經講完,現在已經可以做一些簡單的程序,但是肯定不會如此的做,就像只用servlet,不用jsp頁面或其他模板也可以做出很絢麗的系統,但大部分還是需要jsp頁面或其他模板頁作為支撐,下一章將說明在系統中如何使用jinjia2模板引擎和wtf表單插件。