#!/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