FastAPI での認証と認可に JWT トークンを使用する方法
はじめに:
Web アプリケーションの開発では、ユーザーの認証と認可が重要な部分になっています。 JWT(JSON Web Token)トークンを利用して認証・認可機能を簡単に実装できます。 FastAPI は、認証と認可を処理するためのシンプルで使いやすい機能を提供する、Python ベースの最新の Web フレームワークです。この記事では、FastAPI での認証と認可に JWT トークンを使用する方法について説明します。
- 依存ライブラリのインストール
まず、FastAPI、PyJWT、Passlib などの依存ライブラリをインストールする必要があります。 pip コマンドを使用してインストールできます。
pip install fastapi pip install pyjwt pip install passlib
- 秘密キーの生成
JWT トークンの署名と検証のための秘密キーを生成する必要があります。次のコードを使用して秘密キーを生成できます。
import secrets secret_key = secrets.token_urlsafe(32)
- ユーザー モデルの作成
FastAPI では、アプリケーション内のユーザーを表すユーザー モデルを定義する必要があります。ユーザー モデルは、次のコードを使用して作成できます。
from pydantic import BaseModel class User(BaseModel): username: str password: str
- ルーティング関数と処理関数の作成
次に、ユーザーの認証および認可リクエストを処理するためのルーティング関数と処理関数を作成する必要があります。 。ルーティングおよび処理関数は、次のコードを使用して作成できます。
from fastapi import FastAPI, HTTPException from fastapi.security import HTTPBearer, HTTPAuthorizationCredentials from passlib.context import CryptContext from datetime import datetime, timedelta import jwt app = FastAPI() pwd_context = CryptContext(schemes=["bcrypt"]) security = HTTPBearer() # 模拟数据库中的用户 users_db = { "admin": { "username": "admin", "password": pwd_context.hash("admin123") } } @app.post("/login") def login(user: User): if user.username not in users_db: raise HTTPException(status_code=401, detail="Invalid username") stored_user = users_db[user.username] if not pwd_context.verify(user.password, stored_user["password"]): raise HTTPException(status_code=401, detail="Invalid password") token = generate_token(user.username) return {"access_token": token} def generate_token(username: str) -> str: expiration = datetime.utcnow() + timedelta(minutes=30) payload = {"username": username, "exp": expiration} return jwt.encode(payload, secret_key, algorithm="HS256") @app.get("/users/me") def get_user_profile(credentials: HTTPAuthorizationCredentials = security): token = credentials.credentials try: payload = jwt.decode(token, secret_key, algorithms=["HS256"]) username = payload["username"] if username not in users_db: raise HTTPException(status_code=401, detail="Invalid username") return {"username": username} except jwt.DecodeError: raise HTTPException(status_code=401, detail="Invalid token")
- 関数のテスト
これで、Postman またはその他の HTTP クライアント ツールを使用して機能をテストできます。まず、POST リクエストを使用してログインリクエストを送信し、リクエスト本文にユーザー名とパスワードを含める必要があります。以下に示すように:
リクエスト URL: http://localhost:8000/login
リクエスト本文:
{ "username": "admin", "password": "admin123" }
ログインに成功すると、カードを含むアクセス トークンを受け取ります。応答。例:
{ "access_token": "xxxxxxxxxxxxx" }
次に、GET リクエストを使用してユーザー プロファイルを取得するリクエストを送信し、Authorization ヘッダーのベアラー トークンとしてアクセス トークンを送信します。以下に示すように:
リクエスト URL: http://localhost:8000/users/me
リクエスト ヘッダー: Authorization: Bearer xxxxxxxxxxxx
{ "username": "admin" }
結論: この記事では、FastAPI での認証と認可に JWT トークンを使用する方法について説明します。 PyJWT ライブラリを使用して JWT トークンを生成し、パスワード ハッシュ検証に Passlib ライブラリを使用しました。このアプローチを使用すると、Web アプリケーションを保護するためのユーザー認証および認可機能を簡単に実装できます。 ###
以上がFastAPI での認証と認可に JWT トークンを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

PythonArraysSupportVariousoperations:1)SlicingExtractsSubsets、2)Appending/ExtendingAdddesements、3)inSertingSelementSatspecificpositions、4)remvingingDeletesements、5)sorting/verversingsorder、and6)listenionsionsionsionsionscreatenewlistsebasedexistin

numpyarraysAressertialentionsionceivationsefirication-efficientnumericalcomputations andDatamanipulation.theyarecrucialindatascience、mashineelearning、物理学、エンジニアリング、および促進可能性への適用性、scaledatiencyを効率的に、forexample、infinancialanalyyy

UseanArray.ArrayOverAlistinPythonは、Performance-criticalCode.1)homogeneousdata:araysavememorywithpedelements.2)Performance-criticalcode:Araysofterbetterbetterfornumerumerumericaleperations.3)interf

いいえ、notallistoperationSaresuptedbyarrays、andviceversa.1)arraysdonotsupportdynamicoperationslikeappendorintorintorinsertizizing、whosimpactsporformance.2)リスト

toaccesselementsinapythonlist、useindexing、negativeindexing、slicing、oriteration.1)indexingstartsat0.2)negativeindexingAcsesess.3)slicingextractStions.4)reterationSuseSuseSuseSuseSeSeS forLoopseCheckLentlentlentlentlentlentlenttodExeror。

Arraysinpython、特にvianumpy、arecrucialinscientificComputing fortheirefficienty andversitility.1)彼らは、fornumericaloperations、data analysis、andmachinelearning.2)numpy'simplementation incensuresfasteroperationsthanpasteroperations.3)arayableminablecickick

Pyenv、Venv、およびAnacondaを使用して、さまざまなPythonバージョンを管理できます。 1)Pyenvを使用して、複数のPythonバージョンを管理します。Pyenvをインストールし、グローバルバージョンとローカルバージョンを設定します。 2)VENVを使用して仮想環境を作成して、プロジェクトの依存関係を分離します。 3)Anacondaを使用して、データサイエンスプロジェクトでPythonバージョンを管理します。 4)システムレベルのタスク用にシステムPythonを保持します。これらのツールと戦略を通じて、Pythonのさまざまなバージョンを効果的に管理して、プロジェクトのスムーズな実行を確保できます。

numpyarrayshaveveraladvantages-averstandardpythonarrays:1)thealmuchfasterduetocベースのインプレンテーション、2)アレモレメモリ効率、特にlargedatasets、および3)それらは、拡散化された、構造化された形成術科療法、


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

ドリームウィーバー CS6
ビジュアル Web 開発ツール

ホットトピック









