Auth0\SDK\Auth0、Auth0\SDK\API\Authentication、Auth0\SDK\API\Managementという3つのコアクラスがバンドルされ、それぞれがAuth0 APIの全体にさまざまな機能のインターフェイスを提供しています。ユーザーセッションの追跡が必要なステートフルWebアプリケーションを構築する場合、最も頻繁に使用するクラスは基本のAuth0クラスです。ログインとログアウト、ユーザー資格情報の取得、利用可能なセッションの確認、コールバック処理などの一般的な認証およびセッションのタスクを処理するためのメソッドを提供します。これらのタスクについては、以下で説明します。
これらの機能性などについては、認証APIのドキュメントページを参照してください。
前提条件
以下の内容はAuth0-PHPの手順を終えていることを前提としており、そこで提供されたコードを使用します。ログイン
PHP SDKにデフォルトのログインプロセスは、認証コード付与をAuth0のユニバーサルログインページと組み合わせて使用します。つまり、次のプロセスになります。- アクセスを要求するユーザーがユニバーサルログインページにリダイレクトされます。
- ユーザーがさまざまな接続のいずれかを使用して認証します。接続にはソーシャル(Google、X、Facebook)、データベース(メールとパスワード)、パスワードレス(メール、SMS)、またはエンタープライズ(ActiveDirectory、ADFS、Office 365)などが含まれます。
- ユーザーがアプリケーションのコールバックURLにリダイレクトまたはポストバックされ、成功の場合は
codeとstateの値、失敗の場合はerrorとerror_descriptionが一緒に送信されます。 - 認証が成功した場合は、
state値が検証されます。 stateが有効な場合、code値がAuth0でIDトークンおよび/またはアクセストークンと交換されます。- IDトークンからのIDは、アカウントの作成、アプリケーション固有のセッション開始、ユーザーセッションの永続化に使用できます。
- ユーザーのログインが必要な場合(例:リンクをクリック、ウォールされたコンテンツにアクセスなど)は、
Auth0\SDK\Auth0::login()を呼び出す。 - ユーザーをコールバックURLにリダイレクトする場合は、
Auth0\SDK\Auth0::exchange()を呼び出す。 - ユーザーがログインしているかを確認し、ユーザー情報の取得が必要な場合は、
Auth0\SDK\Auth0::getCredentials()を呼び出す。
- 即座にテナントのAuth0ログインページにリダイレクトします。
- 任意の接続を使用して正常にログインした後で、アプリにリダイレクトします。
- 「認証されました!」と表示するシンプルなページを表示します。