Laravel Fortify を使用して PHP セキュリティ検証を実装する
はじめに:
インターネットの普及に伴い、ネットワーク セキュリティの問題がますます顕著になってきています。ユーザー情報を安全に保つことは、Web アプリケーションを構築および開発する際の重要なタスクです。 PHP のセキュリティ検証を強化するには、検証プロセスを簡素化および強化する強力なツールである Laravel Fortify を使用できます。この記事では、Laravel Fortify の基本概念と使用法を紹介し、読者の理解を深めるためにいくつかのサンプルコードを提供します。
composer require laravel/fortify
インストールが完了したら、次のコマンドを実行して Fortify 構成ファイルを生成する必要があります。
php artisan vendor:publish --provider="LaravelFortifyFortifyServiceProvider"
構成ファイルは config/fortify.php
に生成され、ここでいくつかのカスタム構成を作成できます。
// routes/web.php use LaravelFortifyFortify; // 引入 Fortify 的一些基本配置 Fortify::loginView(function () { return view('auth.login'); }); // 引入 Fortify 的路由 Fortify::authenticateUsing(function (Request $request) { // 用户验证逻辑 }); // 用户认证相关路由 Route::group(['middleware' => config('fortify.middleware', ['web'])], function () { // 注册、登录、密码重置、邮箱验证等路由 Fortify::registerRoutes(); Fortify::resetPasswordRoutes(); Fortify::verifyEmailRoutes(); });
ここでの基本構成には、ユーザー ログイン インターフェイスとユーザー認証ロジックのビューが含まれています。 Fortify は、ニーズに応じて変更またはカスタマイズできるいくつかのプリセット ビュー テンプレートを提供します。
authenticateUsing
メソッドを実装することで、ユーザーの認証方法をカスタマイズできます。以下は簡単な例です: // routes/web.php use LaravelFortifyFortify; use IlluminateSupportFacadesAuth; Fortify::authenticateUsing(function (Request $request) { // 获取表单提交的登录信息 $credentials = $request->only('email', 'password'); // 用户认证逻辑 if (Auth::attempt($credentials)) { return redirect()->intended('/dashboard'); } else { return back()->withErrors([ 'email' => 'Email 或密码不正确', ]); } });
この例では、ユーザー認証に Laravel の Auth
Facade を使用します。アプリケーションのニーズに基づいて、さまざまなユーザー認証方法を使用できます。
config/fortify.php
ファイルで構成できます。一般的に使用される機能の例をいくつか示します: 2 段階認証: Laravel の TwoFactorAuthentication
ミドルウェアを使用して、2 段階認証を有効にします:
Fortify::authenticateThrough(function (Request $request) { return array_filter([ config('fortify.limiters.login') ? null : RateLimiter::for('login'), $request->input('remember') ? null : ThrottleFailedLogins::forUser($request->user()), TwoFactorAuthentication::check($request) ? null : PreventsTwoFactorAuthentication::class, ]); });
ログイン試行回数を制限する: ログイン試行回数とロック時間は config/fortify.php
で設定できます:
'limiters' => [ 'login' => [ 'enabled' => true, 'tries' => 5, 'lockout_time' => 300, ], ],
config/fortify.php
で構成できます。 結論:
Laravel Fortify を使用すると、PHP セキュリティ検証プロセスを簡単に構築および強化できます。この記事では、Laravel Fortify の基本概念と使用法を紹介し、読者の理解を深めるためにいくつかのサンプルコードを提供します。この情報が、ユーザー情報のセキュリティをより適切に保護し、Web アプリケーションの信頼性と信頼性を高めるのに役立つことを願っています。
以上がLaravel Fortify を使用して PHP セキュリティ検証を実装するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。