ユーザー認証と管理は、新しいプロジェクトを開始するときの基本的な機能です。これらのタスクは頻繁に繰り返されるため、プロセスを合理化し、開発者がプロジェクトの他の側面に集中できるようにするためのさまざまなパッケージが開発されています。そのようなパッケージの 1 つが Djoser です。これは、Django REST Framework (DRF) とシームレスに統合して、認証とユーザー管理を処理します。このガイドでは、電子メール機能とカスタム電子メール テンプレートの設定を含め、Djoser を使用して完全なユーザー認証システムを構築する手順を説明します。
プロジェクトのセットアップ
プロジェクトのディレクトリを作成することから始めます:
mkdir userauth
希望の IDE で新しいディレクトリに移動し、仮想環境をセットアップしてアクティブ化します
python venv .venv source .venv/bin/activate
次に、必要なパッケージをインストールします。
pip install django djangorestframework djoser djangorestframework_simplejwt social-auth-app-django drf-yasg
注: social-auth-app-django などの一部の依存関係は、Djoser とともに自動的にインストールされる場合があります。その場合は、明示的な追加をスキップできます
インストールしたら、requirements.txt ファイルを生成して依存関係を追跡します。
pip freeze > requirements.txt
依存関係も含め、requirements.txt ファイルにリストされているインストール済みのパッケージがすべて表示されます。
Django プロジェクトを作成し、サーバーを実行します
django-admin startapp userauth .
これにより、django プロジェクトが作成されます。次に、プロジェクト内にアプリを作成する必要があります
python manage.py startapp accounts
プロジェクト ディレクトリには次のものが含まれているはずです:
.venv (仮想環境)
アカウント/ (認証アプリ)
userauth/ (メインプロジェクトフォルダー)
manage.py
requirements.txt
プロジェクトの構成
必要なパッケージとアプリを settings.py の INSTALLED_APPS セクションに追加します。
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', # Third Party Apps 'rest_framework', 'djoser', 'rest_framework_simplejwt', 'drf_yasg', # Local Apps 'accounts', ]
settings.py を更新して、Django REST フレームワークと SimpleJWT の構成を含めます:
REST_FRAMEWORK = { 'DEFAULT_AUTHENTICATION_CLASSES': ( 'rest_framework_simplejwt.authentication.JWTAuthentication', ), }
カスタム ユーザー モデルを作成しましょう
accounts フォルダーに managers.py ファイルを作成します
accounts/managers.py
from django.contrib.auth.models import BaseUserManager class CustomUserManager(BaseUserManager): def create_user(self, email, username, password=None, **extra_fields) -> None: if not username: raise ValueError("Username is required") if not email: raise ValueError("Email is required") email = self.normalize_email(email) user = self.model(email=email, username=username, **extra_fields) user.set_password(password) user.save() return user def create_superuser(self, email, username, password, **extra_fields): """ Create and save a SuperUser with the given email and password. """ extra_fields.setdefault("is_staff", True) extra_fields.setdefault("is_superuser", True) extra_fields.setdefault("is_active", True) if extra_fields.get("is_staff") is not True: raise ValueError("Superuser must have is_staff=True.") if extra_fields.get("is_superuser") is not True: raise ValueError("Superuser must have is_superuser=True.") return self.create_user(email, username, password, **extra_fields)
accounts/models.py
from django.db import models from django.contrib.auth.models import AbstractUser from accounts.managers import CustomUserManager class CustomUser(AbstractUser): username = None email = models.EmailField(unique=True) is_verified = models.BooleanField(default=False) USERNAME_FIELD = 'email' REQUIRED_FIELDS = [] objects = CustomUserManager() def __str__(self): return self.email
この行を settings.py ファイルに追加します
AUTH_USER_MODEL = 'accounts.CustomUser'
移行を進めてから、ローカル開発サーバーを実行できます
python manage.py makemigrations python manage.py migrate python manage.py runserver
この時点までは問題はないはずです。
Djoser URL の構成
Djoser が提供する URL を、Swagger for API ドキュメントとともにプロジェクトの URL パターンに含めます。
userauth/urls.py
from django.contrib import admin from django.urls import include, path from rest_framework import permissions from drf_yasg.views import get_schema_view from drf_yasg import openapi schema_view = get_schema_view( openapi.Info( title="User Accounts API", default_version="v1", description="REST implementation of Django authentication system using Djoser", contact=openapi.Contact(email="contact@snippets.local"), license=openapi.License(name="BSD License"), ), public=True, permission_classes=(permissions.AllowAny,), ) urlpatterns = [ path('admin/', admin.site.urls), path('api/docs', schema_view.with_ui("swagger", cache_timeout=0), name="swagger-ui"), path('api/', include('djoser.urls')), path('api/', include('djoser.urls.jwt')) ]
ブラウザで http://127.0.0.1:8000/api/docs/ にアクセスして、API ドキュメントを表示します。
Djoser 設定の構成
Djoser 用に構成できるすべての設定は、ここで Djoser の設定にあります
userauth/settings.py
mkdir userauth
ここでは、ユーザーにアクティベーション電子メールを受信するよう要求しています。アクティベーション URL は、ユーザーがクリックするために電子メールに送信されるリンクです。トークンと uid を抽出し、それらを本文として含む post リクエストをプロジェクトのアクティベーション ルートに送信する必要があります
電子メール送信の設定
最後に、メール送信を設定する必要があります。メール送信にはmailtrapを使用します。電子メールをコンソールに送信するか、選択した電子メール サービスに送信するかを選択できます。
コンソールに電子メールを送信するため
python venv .venv source .venv/bin/activate
外部メールサービスの利用
pip install django djangorestframework djoser djangorestframework_simplejwt social-auth-app-django drf-yasg
プレースホルダーを正しい認証情報に置き換えます
これをテストするために、postman を使用してテストします。
新しいユーザーの作成
その後、アクティベーションメールがユーザーに送信されます
電子メールテンプレートのカスタマイズ
メールテンプレートを少しカスタマイズしてみましょう
accounts ディレクトリにテンプレート フォルダーを作成し、次に電子メール フォルダーを作成し、そこにテンプレート フォルダーを作成します
アカウント/テンプレート/メール/activation_email.py
djoser
に付属するデフォルトのメールをカスタマイズします。
pip freeze > requirements.txt
テンプレート内のサイト名をカスタマイズするには、この行を djoser 設定に追加します
django-admin startapp userauth .
メール テンプレートは次のようになります
アクティベーション ビューの拡張
この記事の最後の部分では、電子メールの検証に取り組みます。
まず、accounts/views.py のアクティベーション ビューをカスタマイズします:
accounts/views.py
python manage.py startapp accounts
djoser のアクティベーション ビューを拡張してカスタマイズし、ユーザー モデルの is_verified フィールドを true に設定します
accounts/urls.py
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', # Third Party Apps 'rest_framework', 'djoser', 'rest_framework_simplejwt', 'drf_yasg', # Local Apps 'accounts', ]
プロジェクト レベルの URL ファイル
userauth/urls.py
REST_FRAMEWORK = { 'DEFAULT_AUTHENTICATION_CLASSES': ( 'rest_framework_simplejwt.authentication.JWTAuthentication', ), }
これをテストするには、新しいテスト ユーザーを作成し、電子メールに送信されたアクティベーション URL をクリックします。
URL がプロジェクトに存在しないため、このページにアクセスできます
URL から UID とトークンを抽出し、accounts/urls.py ファイルで定義したアクティベーション ルートにポスト リクエストを作成します
スクリーンショットから、私のルートは ;
mkdir userauth
UID は MTY です
トークンは cil456-aaf8331efb885f0b4412f35ce544648c
パラメータを使用して、アクティブ化エンドポイントへのポストリクエストを行う
これで、Djoser を使用したユーザー認証を設定するチュートリアルは終了です。これで、電子メールによるアクティベーションとカスタマイズ可能なテンプレートを備えた機能的な認証システムが完成しました。このシリーズの第 2 部では、ユーザーが Google、Facebook、GitHub などのサードパーティ サービスを使用してサインアップおよびログインできるようにするソーシャル認証について説明します。続報をお楽しみに!
ご質問やフィードバックがございましたら、お気軽にコメントを残してください。
以上がDjango、Djoser、および JWT を使用したユーザー認証のステップバイステップ ガイド: パート Iの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

toAppendElementStoapyThonList、usetheappend()methodforsingleelements、extend()formultipleElements、andinsert()forspecificopsitions.1)useappend()foraddingoneElementatheend.2)useextend()toaddmultipleelementseffictience.3)

To CreateapythonList、usesquareBrackets []およびSeparateItemswithcommas.1)listsaredynamicandcanholdmixdatatypes.2)useappend()、remaid()、andslicingformanipulation.3)listcompreheNsionsionsionsionsionsionsionsionsionsionsionsionsionsionsionsionsionsientionforcreating.4)

金融、科学研究、医療、およびAIの分野では、数値データを効率的に保存および処理することが重要です。 1)財務では、メモリマッピングされたファイルとnumpyライブラリを使用すると、データ処理速度が大幅に向上する可能性があります。 2)科学研究の分野では、HDF5ファイルはデータストレージと取得用に最適化されています。 3)医療では、インデックス作成やパーティション化などのデータベース最適化テクノロジーがデータのパフォーマンスを向上させます。 4)AIでは、データシャーディングと分散トレーニングがモデルトレーニングを加速します。システムのパフォーマンスとスケーラビリティは、適切なツールとテクノロジーを選択し、ストレージと処理速度の間のトレードオフを検討することにより、大幅に改善できます。

pythonarraysarasarecreatedusingthearraymodule、notbuilt-inlikelists.1)importthearraymodule.2)specifytheTypecode、emg。、 'i'forintegers.3)Arraysofferbettermemoreefficiency forhomogeneousdatabutlasefutablethanlists。

Shebangラインに加えて、Pythonインタープリターを指定するには多くの方法があります。1。コマンドラインから直接Pythonコマンドを使用します。 2。バッチファイルまたはシェルスクリプトを使用します。 3. makeやcmakeなどのビルドツールを使用します。 4. Invokeなどのタスクランナーを使用します。各方法には利点と短所があり、プロジェクトのニーズに合った方法を選択することが重要です。

forhandlinglaredataSetsinpython、usenumpyArrays forbetterperformance.1)numpyarraysarememory-effictientandfasterfornumericaloperations.2)nusinnnnedarytypeconversions.3)レバレッジベクトル化は、測定済みのマネージメーシェイメージーウェイズデイタイです

inpython、listsusedynamicmemoryallocation with allocation、whilenumpyArraysalocatefixedmemory.1)listsallocatemorememorythanneededededinitivative.2)numpyArrayasallocateexactmemoryforements、rededicablebutlessflexibilityを提供します。

inpython、youcanspecthedatatypeyfelemeremodelernspant.1)usenpynernrump.1)usenpynerp.dloatp.ploatm64、フォーマーpreciscontrolatatypes。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン
