如何使用 Flask 編寫 Python Web API

2019-12-21 11:23:00

這是一個快速教學,用來展示如何通過 Flask(目前發展最迅速的 Python 框架之一)來從伺服器獲取資料。

Python 是一個以語法簡潔著稱的高階的、物件導向的程式語言。它一直都是一個用來構建 RESTful API 的頂級程式語言。

Flask 是一個高度可客製化化的 Python 框架,可以為開發人員提供使用者存取資料方式的完全控制。Flask 是一個基於 Werkzeug 的 WSGI 工具包和 Jinja 2 模板引擎的”微框架“。它是一個被設計來開發 RESTful API 的 web 框架。

Flask 是 Python 發展最迅速的框架之一,很多知名網站如:Netflix、Pinterest 和 LinkedIn 都將 Flask 納入了它們的開發技術棧。下面是一個簡單的範例,展示了 Flask 是如何允許使用者通過 HTTP GET 請求來從伺服器獲取資料的。

初始化一個 Flask 應用

首先,建立一個你的 Flask 專案的目錄結構。你可以在你系統的任何地方來做這件事。

$ mkdir tutorial$ cd tutorial$ touch main.py$ python3 -m venv env$ source env/bin/activate(env) $ pip3 install flask-restfulCollecting flask-restfulDownloading https://files.pythonhosted.org/packages/17/44/6e49...8da4/Flask_RESTful-0.3.7-py2.py3-none-any.whlCollecting Flask>=0.8 (from flask-restful)[...]

匯入 Flask 模組

然後,在你的 main.py 程式碼中匯入 flask 模組和它的 flask_restful 庫:

from flask import Flaskfrom flask_restful import Resource, Apiapp = Flask(__name__)api = Api(app)class Quotes(Resource):    def get(self):        return {            'William Shakespeare': {                'quote': ['Love all,trust a few,do wrong to none',                'Some are born great, some achieve greatness, and some greatness thrust upon them.']        },        'Linus': {            'quote': ['Talk is cheap. Show me the code.']            }        }api.add_resource(Quotes, '/')if __name__ == '__main__':    app.run(debug=True)

執行 app

Flask 包含一個內建的用於測試的 HTTP 伺服器。來測試一下這個你建立的簡單的 API:

(env) $ python main.py * Serving Flask app "main" (lazy loading) * Environment: production   WARNING: This is a development server. Do not use it in a production deployment.   Use a production WSGI server instead. * Debug mode: on * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)

啟動開發伺服器時將啟動 Flask 應用程式,該應用程式包含一個名為 get 的方法來響應簡單的 HTTP GET 請求。你可以通過 wgetcurl 命令或者任意的 web 瀏覽器來測試它。

$ curl http://localhost:5000{    "William Shakespeare": {        "quote": [            "Love all,trust a few,do wrong to none",            "Some are born great, some achieve greatness, and some greatness thrust upon them."        ]    },    "Linus": {        "quote": [            "Talk is cheap. Show me the code."        ]    }}

要檢視使用 Python 和 Flask 的類似 Web API 的更複雜版本,請導航至美國國會圖書館的 Chronicling America 網站,該網站可提供有關這些資訊的歷史報紙和數位化報紙。

為什麼使用 Flask?

Flask 有以下幾個主要的優點:

  1. Python 很流行並且廣泛被應用,所以任何熟悉 Python 的人都可以使用 Flask 來開發。
  2. 它輕巧而簡約。
  3. 考慮安全性而構建。
  4. 出色的文件,其中包含大量清晰,有效的範例程式碼。

還有一些潛在的缺點:

  1. 它輕巧而簡約。但如果你正在尋找具有大量綑綁庫和預製元件的框架,那麼這可能不是最佳選擇。
  2. 如果必須圍繞 Flask 構建自己的框架,則你可能會發現維護自定義項的成本可能會抵消使用 Flask 的好處。

如果你要構建 Web 程式或 API,可以考慮選擇 Flask。它功能強大且健壯,並且其優秀的專案文件使入門變得容易。試用一下,評估一下,看看它是否適合你的專案。

在本課中了解更多資訊關於 Python 例外處理以及如何以安全的方式進行操作。