目次
1. 追加の検証条件を追加する
2. パスワードの有効期限の検証
ホームページ PHPフレームワーク Laravel カスタマイズされたニーズに合わせてlaravelでログイン検証を変更する方法

カスタマイズされたニーズに合わせてlaravelでログイン検証を変更する方法

Apr 21, 2023 am 10:06 AM

Laravel は、Web アプリケーションを構築するための便利な機能を多数提供する非常に人気のある PHP フレームワークです。その中でも、Laravel独自のユーザー認証システムは、開発者がWebアプリケーションを構築する際に非常に基本的な機能です。デフォルトでは、Laravel のユーザー認証システムはログイン時にユーザーを認証しますが、場合によってはニーズに合わせて変更する必要があります。

この記事では、カスタマイズされたニーズに合わせて Laravel ユーザーのログイン認証を変更する方法を紹介します。読者に 2 つの一般的なシナリオを提供し、これらの状況を解決する方法について説明します:

  1. ユーザーのログイン時に追加の検証条件を追加したい;
  2. パスワードが次のとおりであることを検証したいログイン後に期限切れになりました。有効期限が切れた場合、ユーザーはパスワードをリセットする必要があります。

1. 追加の検証条件を追加する

Laravel のデフォルトのユーザー認証システムでは、ユーザーは正しいメールアドレスとパスワードを入力するだけでログインを完了できます。ただし、対象を絞った検証のためにユーザーに追加情報の提供が必要になる場合があります。

たとえば、ユーザーがロボットではないことを確認するために、セキュリティの質問に対する回答をユーザーに要求します。この照合は、ユーザーが保存した秘密の質問と回答をデータベースから取得し、ユーザーが提供した情報と比較することで実行できます。この検証を実装する方法は次のとおりです。

まず、LoginControllerlogin メソッドをオーバーライドして、セキュリティの質問の答えを検証する必要があります。次のように記述できます。

public function login(Request $request)
{
    $answer = $request->input('answer');
    $user = User::where('email', $request->email)->first();
  
    if (!$user) {
        return redirect()->route('login')
            ->withInput($request->only('email', 'remember'))
            ->withErrors([
                'email' => 'The provided credentials are incorrect.',
            ]);
    }

    if ($user->isRobot() || $user->answer !== $answer) {
        return redirect()->route('login')
            ->withInput($request->only('email', 'remember'))
            ->withErrors([
                'email' => 'The provided credentials are incorrect.',
            ]);
    }

    if (Auth::attempt(['email' => $request->email, 'password' => $request->password], $request->remember)) {
        return redirect()->intended('/dashboard');
    }

    return redirect()->route('login')
        ->withInput($request->only('email', 'remember'))
        ->withErrors([
            'email' => 'The provided credentials are incorrect.',
        ]);
}
ログイン後にコピー

上記のコードでは、まずユーザーから提供された回答を取得し、次にデータベースからユーザーを検索します。ユーザーが存在しない場合は、すぐにログイン ページに戻り、提供された資格情報が間違っていることをユーザーに伝えます。

ユーザーがロボットとしてマークされている場合、または提供された回答がデータベース内のフィールドと一致しない場合も、ユーザーをログイン ページにリダイレクトします。

ただし、ユーザーがセキュリティの質問の検証に合格した場合は、Auth::attempt() メソッドを呼び出してユーザーのログインを試行します。ログインが成功すると、ユーザーは最初に要求したページにリダイレクトされます。

2. パスワードの有効期限の検証

アプリケーションでパスワードの有効期限チェック機能が必要な場合は、Laravel の Auth モジュールを使用してユーザーのパスワードの有効期限のタイムスタンプをチェックできます。タイムスタンプがパスワードの有効期限が切れていることを示している場合は、ユーザーにパスワードをリセットするよう求めることができます。

まず、User モデルにパスワード有効期限タイムスタンプ フィールドを追加する必要があります:

protected $dates = ['password_updated_at'];
ログイン後にコピー

次に、Authenticatable インターフェイスで hasPasswordExpired( をオーバーライドする必要があります。 )メソッド:

public function hasPasswordExpired()
{
    $expirationDate = Carbon::now()->subDays(config('auth.password_expiration_days'));
    return $this->password_updated_at->lt($expirationDate);
}
ログイン後にコピー

上記のコードでは、まずパスワードの有効期限が切れる前の現在時刻と日付を取得し、それを有効期限変数に代入します。次に、パスワード更新のタイムスタンプと有効期限を比較します。パスワードの有効期限タイムスタンプが有効期限より前の場合、パスワードは期限切れです。

次に、LoginControllerlogin() メソッドを更新して、パスワードの有効期限の検出を有効にする必要があります。これを行うには、次のコード スニペットを追加する必要があります。

public function login(Request $request)
{
    $credentials = $request->only('email', 'password');

    if (Auth::attempt($credentials)) {
        if (Auth::user()->hasPasswordExpired()) {
            Auth::logout();
            return redirect('login')->withErrors(['password' => 'Your password has expired. Please reset it.']);
        }

        return redirect()->intended('/dashboard');
    }

    return redirect('login')->withErrors(['email' => 'Your email or password is incorrect.']);
}
ログイン後にコピー

上記のコードでは、ユーザーのログイン後にパスワードの有効期限が切れた場合、エラー メッセージを含むリダイレクト応答が返されます。ユーザーはアプリケーションの使用を続けるためにパスワードのリセットを実行する必要があります。

概要:

上記は、2 つの一般的な状況で Laravel ユーザーのログイン検証を変更するためのソリューションです。最初のケースは、ユーザーがログインするときに追加の検証条件を追加するもので、セキュリティの質問を使用してユーザーが人間であるかどうかを検証します。 2 番目の状況は、ログイン後にパスワードの有効期限が切れているかどうかを確認することです。有効期限が切れた場合、ユーザーはパスワードをリセットする必要があります。

Laravel のデフォルトの認証システムは非常に強力で、さまざまな種類のアプリケーションのニーズを満たす多くの機能とオプションが含まれています。これを変更および拡張することで、特定のニーズに適合させることができます。

以上がカスタマイズされたニーズに合わせてlaravelでログイン検証を変更する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Laravelのコンポーネントを使用して再利用可能なUI要素を作成するにはどうすればよいですか? Laravelのコンポーネントを使用して再利用可能なUI要素を作成するにはどうすればよいですか? Mar 17, 2025 pm 02:47 PM

この記事では、コンポーネントを使用してLaravelで再利用可能なUI要素の作成とカスタマイズについて説明し、組織のベストプラクティスを提供し、パッケージを強化することを提案します。

Laravelでカスタムブレードディレクティブを作成および使用するにはどうすればよいですか? Laravelでカスタムブレードディレクティブを作成および使用するにはどうすればよいですか? Mar 17, 2025 pm 02:50 PM

この記事では、Laravelでカスタムブレードディレクティブの作成と使用を行い、テンプレートを強化します。ディレクティブの定義、テンプレートでそれらを使用し、大規模なプロジェクトでそれらを管理することをカバーし、改善されたコードの再利用性やRなどの利点を強調しています

Laravelでカスタム検証ルールを作成して使用するにはどうすればよいですか? Laravelでカスタム検証ルールを作成して使用するにはどうすればよいですか? Mar 17, 2025 pm 02:38 PM

この記事では、Laravelでカスタム検証ルールの作成と使用について説明し、それらを定義および実装する手順を提供します。再利用性や特異性などの利点を強調し、Laravelの検証システムを拡張する方法を提供します。

Laravelの職人コンソールを使用して一般的なタスクを自動化するにはどうすればよいですか? Laravelの職人コンソールを使用して一般的なタスクを自動化するにはどうすればよいですか? Mar 17, 2025 pm 02:39 PM

Laravelの職人コンソールは、コードの生成、移行の実行、スケジューリングなどのタスクを自動化します。重要なコマンドには、Make:Controller、Migrate、およびDB:Seedが含まれます。特定のニーズに合わせてカスタムコマンドを作成し、ワークフロー効率を向上させることができます。

Laravelのルーティング機能を使用して、SEOに優しいURLを作成するにはどうすればよいですか? Laravelのルーティング機能を使用して、SEOに優しいURLを作成するにはどうすればよいですか? Mar 17, 2025 pm 02:43 PM

この記事では、Laravelのルーティングを使用してSEOに優しいURLを作成し、Best Practice、Canonical URL、SEO最適化のツールをカバーします。ワード数:159

どちらが良いのか、DjangoとLaravel? どちらが良いのか、DjangoとLaravel? Mar 28, 2025 am 10:41 AM

DjangoとLaravelはどちらもフルスタックのフレームワークです。 DjangoはPython開発者や複雑なビジネスロジックに適していますが、LaravelはPHP開発者とエレガントな構文に適しています。 1.DjangoはPythonに基づいており、迅速な発展と高い並行性に適した「バッテリーコンプリート」哲学に従います。 2. LaravelはPHPに基づいており、開発者エクスペリエンスを強調しており、小規模から中規模のプロジェクトに適しています。

Laravelでデータベーストランザクションを使用してデータの一貫性を確保するにはどうすればよいですか? Laravelでデータベーストランザクションを使用してデータの一貫性を確保するにはどうすればよいですか? Mar 17, 2025 pm 02:37 PM

この記事では、Laravelでデータベーストランザクションを使用して、データの一貫性を維持し、DBファサードと雄弁なモデルを使用した方法の詳細、ベストプラクティス、例外処理、およびトランザクションの監視とデバッグのためのツールについて説明します。

アプリケーションのパフォーマンスを改善するために、Laravelにキャッシュを実装するにはどうすればよいですか? アプリケーションのパフォーマンスを改善するために、Laravelにキャッシュを実装するにはどうすればよいですか? Mar 17, 2025 pm 02:35 PM

この記事では、ララヴェルでキャッシュを実装して、パフォーマンスを高め、構成をカバーし、キャッシュファサード、キャッシュタグ、原子操作を使用して、パフォーマンスをカバーします。また、キャッシュ構成のベストプラクティスの概要を説明し、キャッシュするデータの種類を提案します

See all articles