ホームページ >バックエンド開発 >Python チュートリアル >Python サーバー プログラミング: Flask を使用した RESTful API の構築
Python サーバー プログラミング: Flask を使用して RESTful API を構築する
Python は、Web アプリケーション開発で常に人気のある言語の 1 つです。柔軟で効率的な言語。 Web アプリケーションで RESTful API を使用することは、非常に人気のあるトレンドになっています。 Python で Flask フレームワークを使用することは、Web プログラミングと RESTful API の構築に最適なオプションです。この記事では、Flask フレームワークを使用して RESTful API を構築する方法を詳しく見ていきます。
まず、RESTful API を理解する必要があります。 RESTful API は、HTTP/HTTPS プロトコルに基づく API 設計スタイルであり、統一インターフェイスを使用してクライアントとサーバーの間でデータを送信します。 RESTful API には次の特徴があります。
次に、Flask フレームワークを使用して RESTful API を構築します。 Flask は、Python で書かれた軽量の Web フレームワークで、学習と使用が簡単です。 Flask フレームワークには、さまざまなニーズに対応できる豊富な拡張ライブラリがあります。 Flask フレームワークを使用する利点は次のとおりです。
最初に Flask フレームワークをインストールする必要があります。これは次のコマンドでインストールできます:
pip install flask
次に始めます。 Flask フレームワークを使用して RESTful API を構築します。まず、Hello World プログラムを作成して、Flask フレームワークが正しくインストールされていることを確認する必要があります。 Flask アプリケーションを定義し、リクエストを処理するルート '/' を定義できます。コードは次のとおりです。
from flask import Flask app = Flask(__name__) @app.route('/') def helloWorld(): return 'Hello, World!' if __name__ == '__main__': app.run(debug=True)
ブラウザに「http://localhost:5000/」と入力すると、「Hello, World!」が表示されます。
次に、Flask フレームワークを使用して RESTful API を構築する方法を紹介します。
まず、Flask アプリケーションを定義し、GET リクエストに応答するルートを作成します。コードは次のとおりです:
from flask import Flask, jsonify app = Flask(__name__) books = [ { 'id': 1, 'title': 'The Great Gatsby', 'author': 'F. Scott Fitzgerald', 'published': '1925' }, { 'id': 2, 'title': 'To Kill a Mockingbird', 'author': 'Harper Lee', 'published': '1960' } ] @app.route('/books/<int:id>', methods=['GET']) def get_book(id): for book in books: if book['id'] == id: return jsonify(book) return jsonify({'error': 'Book not found'}) if __name__ == '__main__': app.run(debug=True)
上記のコードでは、2 つの辞書を含む書籍リストを定義します。 、各 A 辞書は本を表します。ルート「/books/」が定義され、「3e2f7d559aac0f0aeba61111f4764f61」を使用して整数の ID パラメータが渡されます。この関数では、ID で書籍を検索し、見つかった場合は書店の詳細を返し、見つからない場合はエラー メッセージを返します。
ブラウザに「http://localhost:5000/books/1」と入力すると、「The Great Gatsby」という名前の書籍に関する詳細情報が返されます。
次に、上記のコードを拡張して、HTTP リクエストの他のメソッドをサポートします。
@app.route('/books', methods=['GET', 'POST']) def handle_books(): if request.method == 'GET': return jsonify(books) if request.method == 'POST': new_book = { 'id': len(books) + 1, 'title': request.form['title'], 'author': request.form['author'], 'published': request.form['published'] } books.append(new_book) return jsonify(new_book)
上記のコードでは、HTTP GET リクエストと POST リクエストを処理するための新しいルート '/books' を定義しました。 GET リクエストでは、書籍リスト全体を返します。 POST リクエストでは、新しい書籍を書籍リストに追加します。
次に、DELETE メソッドと PUT メソッドを実装します。
@app.route('/books/<int:id>', methods=['GET', 'PUT', 'DELETE']) def handle_book(id): if request.method == 'GET': for book in books: if book['id'] == id: return jsonify(book) return jsonify({'error': 'Book not found'}) if request.method == 'PUT': for book in books: if book['id'] == id: book['title'] = request.form['title'] book['author'] = request.form['author'] book['published'] = request.form['published'] return jsonify(book) return jsonify({'error': 'Book not found'}) if request.method == 'DELETE': for book in books: if book['id'] == id: books.remove(book) return jsonify({'message': 'Book deleted'}) return jsonify({'error': 'Book not found'})
上記のコードでは、ルート「/books/3e2f7d559aac0f0aeba61111f4764f61」の処理を拡張しています。 GET リクエストでは、ID に関連付けられた書籍を検索します。 PUT リクエストでは、ID に関連付けられた書籍を更新します。 DELETEリクエストでは、idに関連する書籍を削除します。
これまで、Flask を使用して RESTful API を構築する方法を学習しました。 Flask を使用してリソースを定義し、それらを HTTP リクエストに公開する方法を説明しました。また、さまざまな REST プラクティスを使用して GET、POST、PUT、および DELETE 操作を実装する方法も学びました。さらに、Flask 応答を使用してデータを返す方法も確認しました。
つまり、Flask フレームワークは、RESTful API を実装するための理想的な選択肢であり、高速かつシンプルで、学習と使用が簡単で、Python 言語をサポートしています。この記事では、Flask を使用して RESTful API を構築する方法を示します。非常に簡単なので、アプリケーションにサービスを提供する独自の RESTful API の作成を開始できます。
以上がPython サーバー プログラミング: Flask を使用した RESTful API の構築の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。