專 欄 夏軒,Python中文社區(qū)專欄作者。 博客:http://blog.csdn.net/u012734441
1.flask介紹flask是一款十分輕量級(jí)的python Web應(yīng)用框架,也被認(rèn)為是一種微框架,我最初喜歡使用是因?yàn)閒lask中提供的那一套使用的注解跟我當(dāng)時(shí)在公司中使用java開發(fā)的系統(tǒng),里面使用的restful的框架jersey的用法比較像,都十分方便,簡(jiǎn)潔,等到我熟悉使用flask框架之后,就挺喜歡這種微框架了,使用方便,配置簡(jiǎn)單,也可以進(jìn)行克重?cái)U(kuò)展,滿足各自的需求,其中在這些里面還有一個(gè)flask restplus,將swagger工具整合到python里面,在進(jìn)行相應(yīng)測(cè)試的時(shí)候十分方便,這個(gè)放到下一期再講。 2.所需工具和環(huán)境 這一次運(yùn)行flask需要使用的flask環(huán)境就不在物理機(jī)上安裝運(yùn)行了,直接使用上一篇講述的virtualenv來安裝flask,寫出來的app demo都是依賴在虛擬環(huán)境運(yùn)行的,以下是我們這次演示所需要的python工具和相應(yīng)包。
以pycharm作為python ide, virtualenv以python 2.7創(chuàng)建我們的python運(yùn)行環(huán)境,并用 pip install flask,環(huán)境搭建基本就完成了,下面是具體流程。 3.搭建flaskApp 3.1 設(shè)置虛擬化環(huán)境 打開pycharm,新建工程命名為flaskApp,完成后如下: 現(xiàn)在基本是一個(gè)空工程,現(xiàn)在打開控制臺(tái),輸入以下命令,創(chuàng)建虛擬化環(huán)境:
控制臺(tái)輸出完成后,將會(huì)在當(dāng)前目錄中創(chuàng)建一個(gè)venv文件夾,里面是我們運(yùn)行python的虛擬化環(huán)境,在這里我并沒有指明使用哪種版本的python環(huán)境是因?yàn)楫?dāng)前系統(tǒng)默認(rèn)的環(huán)境是python2.7,如果想使用python3.0以上可以參考前一篇文章virtualenv介紹及基本使用來完成。 現(xiàn)在要做的第二步就是啟動(dòng)當(dāng)前的虛擬化環(huán)境,輸入命令source venv/bin/active,完成后控制臺(tái)將會(huì)如下所示: (venv) localhost:flaskApp xiaxuan$ 表示我們的虛擬化環(huán)境啟動(dòng)成功,但是現(xiàn)在并不是表示當(dāng)前pycharm中當(dāng)前工程的工作環(huán)境就是venv中的虛擬化環(huán)境,這里要設(shè)置pycharm中的python interpreter改為當(dāng)前項(xiàng)目的運(yùn)行環(huán)境才行。 安裝flask的命令如下:
由于虛擬化環(huán)境,所以不需要root權(quán)限,十分方便。 在安裝完相應(yīng)依賴,設(shè)置好python運(yùn)行環(huán)境后,在項(xiàng)目根目錄下新建requirements.txt文件,這個(gè)文件主要就是記載當(dāng)前項(xiàng)目安裝了那些依賴,文件內(nèi)容如下:
這是目前安裝的依賴,前面是包名,后面是版本號(hào),由于這個(gè)的存在我們可以直接在項(xiàng)目沒有安裝這些package之前,將所需的package寫進(jìn)來,然后在控制臺(tái)使用pip install -r requirements.txt,就可以將這些依賴全部安裝進(jìn)來。 3.2 搭建flask工作目錄 一個(gè)完整的flask項(xiàng)目的完整目錄以及基本的如下所示:
以上就是簡(jiǎn)單的flask項(xiàng)目基本目錄。 4. 具體程序編寫 4.1源碼 views.py:
上圖提供兩個(gè)接口,一個(gè)是渲染視圖index.html,一個(gè)是返回json結(jié)果,較為簡(jiǎn)單,而在flask中接口的路由就是一個(gè)簡(jiǎn)簡(jiǎn)單單的注解app.route完成的,指定是哪一種http請(qǐng)求訪問也是非常簡(jiǎn)單的,指定methods即可,methods是一個(gè)數(shù)組,即GET,POST可以同時(shí)在一個(gè)請(qǐng)求之中,但是我們?cè)趯懡涌诘臅r(shí)候,一般都會(huì)區(qū)分清楚。 在上面有一個(gè)
在這里聲明了app對(duì)象,在views中我們引用了app,同時(shí)在下面一個(gè)文件run.py中,app起著啟動(dòng)整個(gè)項(xiàng)目的作用,run.py源碼如下:
十分簡(jiǎn)單明了,app.run()整個(gè)項(xiàng)目便運(yùn)行起來了,在這里運(yùn)行的時(shí)候,項(xiàng)目是默認(rèn)的端口為5000,如果需要指定端口,app.run()方法中指定port即可。 4.2 運(yùn)行 啟動(dòng)run.py后,控制臺(tái)如下: 控制臺(tái)輸出已經(jīng)在5000端口上運(yùn)行起來,現(xiàn)在我們請(qǐng)求http://localhost:5000,轉(zhuǎn)向界面為: 這是先前views.py中的第一個(gè)接口,渲染index.html,index.html中的內(nèi)容就是hello world。 訪問第二個(gè)接口,url為http://localhost:5000/hello,結(jié)果如下: 返回json數(shù)據(jù)。 5. 綜上
文中代碼及完整資料已上傳至Python中文社區(qū)小密圈,歡迎討論并下載資料。 歡迎加入 Python中文社區(qū) 小密圈 |
|