맞춤형 미들웨어 구현 :
Laravel의 미들웨어는 응용 프로그램을 입력하는 HTTP 요청을 필터링하기위한 강력한 메커니즘을 제공합니다. 사용자 정의 미들웨어를 만들면 요청 라이프 사이클에 자신의 논리를 주입 할 수 있습니다. 단계별 가이드는 다음과 같습니다.
php artisan make:middleware CheckAge
. 이렇게하면 app/Http/Middleware/CheckAge.php
에서 새로운 미들웨어 파일이 생성됩니다.handle
메소드 내에 사용자 정의 로직을 배치합니다. 이 메소드는 요청 ( $request
) 및 폐쇄 ( $next
)를 수신합니다. 폐쇄는 다음 미들웨어 또는 경로 처리기를 나타냅니다. 예:<code class="php"><?php namespace App\Http\Middleware; use Closure; use Illuminate\Http\Request; class CheckAge { /** * Handle an incoming request. * * @param \Illuminate\Http\Request $request * @param \Closure(\Illuminate\Http\Request): (\Illuminate\Http\Response|\Illuminate\Http\RedirectResponse) $next * @return \Illuminate\Http\Response|\Illuminate\Http\RedirectResponse */ public function handle(Request $request, Closure $next) { if ($request->age </code>
app/Http/Kernel.php
에 새로 생성 된 미들웨어를 등록해야합니다. $routeMiddleware
배열에 추가하십시오.<code class="php">protected $routeMiddleware = [ // ... other middleware ... 'checkage' => \App\Http\Middleware\CheckAge::class, ];</code>
routes/web.php
또는 routes/api.php
에서 특정 경로 또는 경로 그룹에 할당하십시오.<code class="php">Route::get('/profile', [ProfileController::class, 'show'])->middleware('checkage');</code>
사용자 정의 필터 구현 (참고 : Laravel의 용어는 일반적으로 "필터"대신 "미들웨어"를 사용합니다) :
Laravel은 일부 이전 프레임 워크와 같은 방식으로 "필터"라는 용어를 명시 적으로 사용하지는 않지만 미들웨어는 효과적으로 동일한 목적을 제공합니다. 위의 코드 예제는 연령을 확인하고 조건이 충족되지 않은 경우 리디렉션하여 필터와 같은 동작을 보여줍니다. 미들웨어 내의 handle
방법은 필터 기능 역할을합니다.
handle
방법 내부에 생성하는 대신 미들웨어 생성자에 종속성을 주입하십시오. 이것은 테스트 가능성과 유지 관리를 향상시킵니다. Laravel은 인증을위한 내장 미들웨어 ( auth
) 및 권한 부여 ( auth.basic
, can
등)를 제공합니다. 이를 직접 사용하거나 사용자 정의 미들웨어를 만들어 인증/인증 로직을 확장하거나 사용자 정의 할 수 있습니다.
내장 미들웨어 사용 예 :
<code class="php">Route::get('/profile', [ProfileController::class, 'show'])->middleware('auth'); //Requires authentication Route::get('/admin', [AdminController::class, 'index'])->middleware('auth', 'admin'); //Requires authentication and admin role (assuming you have an 'admin' middleware defined)</code>
사용자 정의 인증 미들웨어의 예 :
<code class="php"><?php namespace App\Http\Middleware; use Closure; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; class CheckAdmin { public function handle(Request $request, Closure $next) { if (Auth::check() && Auth::user()->isAdmin()) { return $next($request); } abort(403, 'Unauthorized'); // Return 403 Forbidden if not an admin } }</code>
이 CheckAdmin
Middleware를 app/Http/Kernel.php
파일에 등록하십시오.
try...catch
블록을 사용하십시오.app/Http/Kernel.php
의 $routeMiddleware
배열에 사용자 정의 미들웨어를 올바르게 등록하십시오. 일반적인 실수는이 단계를 잊어 버리고 미들웨어를 비효율적으로 만듭니다.위 내용은 Laravel 애플리케이션에서 사용자 정의 미들웨어 및 필터를 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!