1. 程式人生 > >Flask 框架app = Flask(__name__) 解析

Flask 框架app = Flask(__name__) 解析

#!/usr/local/bin/python
# coding=utf-8

from flask import Flask
app = Flask(__name__)

@app.route('/')
def hello_world():
    return 'Hello World!'

if __name__ == '__main__':
    app.run(host='0.0.0.0',port=9000)
'''
第4行,引入Flask類,Flask類實現了一個WSGI應用
第5行,app是Flask的例項,它接收包或者模組的名字作為引數,但一般都是傳遞__name__。
    讓flask.helpers.get_root_path函式通過傳入這個名字確定程式的根目錄,以便獲得靜態檔案和模板檔案的目錄。
第7~9行,使用app.route裝飾器會將URL和執行的檢視函式的關係儲存到app.url_map屬性上。
    處理URL和檢視函式的關係的程式就是路由,這裡的檢視函式就是hello_world。
第11行,使用這個判斷可以保證當其他檔案引用這個檔案的時候(例如“from hello import app”)不會執行這個判斷內的程式碼,也就是不會執行app.run函式。
第12行,執行app.run就可以啟動服務了。預設Flask只監聽虛擬機器的本地127.0.0.1這個地址,埠為5000。
    而我們對虛擬機器做的埠轉發埠是9000,所以需要制定host和port引數,0.0.0.0表示監聽所有地址,這樣就可以在本機訪問了。
    伺服器啟動後,會呼叫werkzeug.serving.run_simple進入輪詢,預設使用單程序單執行緒的werkzeug.serving.BaseWSGIServer處理請求,
    實際上還是使用標準庫BaseHTTPServer.HTTPServer,通過select.select做0.5秒的“while TRUE”的事件輪詢。
    當我們訪問“http://127.0.0.1:9000/”,通過app.url_map找到註冊的“/”這個URL模式,就找到了對應的hello_world函式執行,返回“hello world!”,狀態碼為200。
    如果訪問一個不存在的路徑,如訪問“http://127.0.0.1:9000/a”,Flask找不到對應的模式,就會向瀏覽器返回“Not Found”,狀態碼為404
'''