基於flask的最小的應用
建立hello.py檔案
from flask import Flask app = Flask(__name__)@app.route('/')def gello_world(): return 'Hello World'if __name__ == '__main__': app.run()
執行:python hello.py
初始化
from flask import Flask app = Flask(__name__)
Flask類建構函式唯一需要的引數就是應用程式的主模組或包。對於大多數應用程式,Python的name變數就是那個正確的、你需要傳遞的值。Flask使用這個引數來確定應用程式的根目錄,這樣以後可以相對這個路徑來找到資原始檔。
路由
@app.route('/')
客戶端例如web瀏覽器傳送 請求 給web服務,進而將它們傳送給Flask應用程式例項。應用程式例項需要知道對於各個URL請求需要執行哪些程式碼,所以它給Python函式建立了一個URLs對映。這些在URL和函式之間建立聯絡的操作被稱之為 路由 。
在Flask應程式中定義路由的最便捷的方式是透過顯示定義在應用程式例項之上的app.route裝飾器,註冊被裝飾的函式來作為一個 路由。
檢視函式
在上一個示例給應用程式的根URL註冊gello_world()函式作為事件的處理程式。如果這個應用程式被部署在伺服器上並繫結了 域名,然後在你的瀏覽器位址列中輸入 將觸發gello_world()來執行服務。客戶端接收到的這個函式的返回值被稱為 響應 。如果客戶端是web瀏覽器,響應則是顯示給使用者的文件。
類似於gello_world()的函式被稱作 檢視函式 。
動態名稱元件路由
你的Facebook個人資訊頁的URL是 ,所以你的使用者名稱是它的一部分。Flask在路由裝飾器中使用特殊的語法支援這些型別的URLs。下面的示例定義了一個擁有動態名稱元件的路由:
@app.route('/hello/<name>')def gello_world(name): return 'Hello World %s' % name
用尖括號括起來的部分是動態的部分,所以任何URLs匹配到靜態部分都將對映到這個路由。當檢視函式被呼叫,Flask傳送動態元件作為一個引數。在前面的示例的檢視函式中,這個引數是用於生成一個個性的問候作為響應。
在路由中動態元件預設為字串,但是可以定義為其他型別。例如,路由/user/int:id只匹配有一個整數在id動態段的URLs。Flask路由支援int、float
如下:
@app.route('/hello/<int:id>')def gello_stu_id(id): return 'Hello World id: %s' % id
服務啟動
if __name__ == '__main__': # 修改啟動的ip和埠,debug模式 # app.run(host='0.0.0.0', port=8080, debug=True) # python xxx.py runserver -h 0.0.0.0 -p 8080 -d app.run()
注意: name == 'main'在此處使用是用於確保web服務已經啟動當指令碼被立即執行。當指令碼被另一個指令碼匯入,它被看做父指令碼將啟動不同的服務,所以app.run()呼叫會被跳過。
一旦服務啟動,它將進入迴圈等待請求併為之服務。這個迴圈持續到應用程式停止,例如透過按下Ctrl-C。
有幾個選項引數可以給app.run()配置web服務的操作模式。在開發期間,可以很方便的開啟debug模式,將啟用 debugger 和 reloader 。這樣做是透過傳遞debug為True來實現的。
修改啟動方式
安裝外掛
pip install flask-script
調整程式碼 manager = Manager(app=‘自定義的flask物件’)
啟動的地方 manager.run()
啟動命令
python hellow.py runserver -h 地址 -p 埠 -d -r
其中:-h表示地址。-p表示埠。-d表示debug模式。-r表示自動重啟
作者:GHope
連結:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2618/viewspace-2819212/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 《Flask Web開發 基於Python的Web應用開發實戰》簡評FlaskWebPython
- 《Flask Web開發:基於Python的Web應用開發實戰》學習筆記(二)FlaskWebPython筆記
- 基於Dapr的 Azure 容器應用
- 基於 Bootstrap 和 jQuery 的 checkbox 的應用bootjQuery
- 基於react的影院購票應用React
- 基於SpringBoot的國際化應用Spring Boot
- 基於Redis分散式BitMap的應用Redis分散式
- Flask 應用如何部署Flask
- 基於 Babel 的 npm 包的最小化設定BabelNPM
- 基於Python的web架構之Tornado+FlaskPythonWeb架構Flask
- 基於PostGIS的高階應用(5)–PolygonSplitingGo
- 基於Flutter的仿微信聊天應用Flutter
- 輕鬆搭建基於 Serverless 的 ThinkPHP 應用ServerPHP
- 基於豆瓣api的快應用專案API
- 基於flask搭建伺服器響應頁面資料Flask伺服器
- 基於 flask 結合 Redis 的簡單聊天室FlaskRedis
- 基於"堆"的底層實現和應用
- 基於HTML5的移動Web應用HTMLWeb
- 基於 React & TypeScript & Webpack 的微前端應用模板ReactTypeScriptWeb前端
- BizWorks 應用平臺基於 KubeVela 的實踐
- Dore 混合應用框架 —— 基於 React Native 的混合應用遷移方案框架React Native
- 用於靜態網站的最小Docker映象 - lipanski網站Docker
- flask分頁功能:基於flask-sqlalchemy和jinja2FlaskSQL
- 如何用Flask中的Blueprints構建大型Web應用FlaskWeb
- Vue-rap 構建基於 Vue 的流應用Vue
- 如何管理基於微服務的分散式應用程式微服務分散式
- WebRTC:基於物聯網的行業化應用Web行業
- 基於Yii2的應用開發引擎RageFrame
- 輕鬆搭建基於 SpringBoot + Vue 的 Web 商城應用Spring BootVueWeb
- Today:基於 Electron 和 Vue.js 的 GTD 應用Vue.js
- 基於應用理解的協議棧最佳化協議
- zabbix應用教程:基於Nginx頁面響應的日誌監控用例Nginx
- 從零構建一個基於Docker的Laravel應用DockerLaravel
- 乾貨|EasyMR 基於 Kubernetes 應用的監控實踐
- 基於中銀智慧風控平臺的應用探索
- 基於 Seata Saga 設計更有彈性的金融應用
- 基於 HTML5 Canvas 的拓撲元件 ToolTip 應用HTMLCanvas元件
- 快速搭建基於 Serverless 的 .NET Core 資料庫應用Server資料庫