>PHP 프레임워크 >Laravel >Laravel 미들웨어 구현 과정

Laravel 미들웨어 구현 과정

WBOY
WBOY원래의
2023-05-20 21:12:35871검색

인터넷과 웹 애플리케이션의 지속적인 발전으로 인해 웹 개발 프레임워크도 등장하고 있으며, 그중 Laravel 프레임워크가 널리 인식되고 사용되고 있습니다. Laravel 프레임워크는 개발자에게 미들웨어의 중요한 기능을 제공하여 애플리케이션의 요청을 필터링하고 처리하여 개발 효율성과 보안을 효과적으로 향상시킵니다. 이 글에서는 개발자들이 이 기능을 더 잘 이해하고 적용할 수 있도록 Laravel 미들웨어의 구현 과정을 자세히 소개하겠습니다.

1. 미들웨어란

Laravel 프레임워크에서 미들웨어(Middleware)는 코드 개념의 일반적인 인터셉터 및 필터와 유사하게 애플리케이션에 들어오는 HTTP 요청을 필터링하고 처리하는 메커니즘을 의미합니다. 일반적인 상황에서 미들웨어는 다음과 같은 일반적인 처리 작업을 수행합니다.

    요청의 액세스 빈도를 확인하고 제한합니다.
  • 헤더 정보를 기반으로 합니다. 요청, 해당 응답 헤더 등을 설정합니다.
  • Laravel 프레임워크는 인증 미들웨어, CSRF 미들웨어, 전류 제한 미들웨어 등과 같은 일부 내장 미들웨어를 제공합니다. 개발자는 애플리케이션의 특정 요구 사항을 충족하기 위해 사용자 정의 미들웨어를 작성할 수도 있습니다.
  • 2. 미들웨어 구현 원리
Laravel 프레임워크의 미들웨어 메커니즘은 PSR-15 표준을 기반으로 구현되었습니다. Laravel에서 미들웨어는 일반적으로 미들웨어 클래스와 미들웨어 호출의 두 부분으로 구성됩니다. 다음으로 이 두 부분을 각각 자세히 소개합니다.

미들웨어 클래스

미들웨어 클래스는 미들웨어 로직 구현의 핵심 부분으로 일반적으로 PSR-15에 정의된 MiddlewareInterface 인터페이스의 프로세스 메소드를 구현해야 합니다. 이 메소드는 현재 요청 객체와 다음 미들웨어나 애플리케이션으로 요청을 전달하는 콜백 함수라는 두 개의 매개변수를 받습니다.
  1. 미들웨어의 처리 로직은 일반적으로 요청 데이터를 읽고, 응답 데이터를 수정하고, 기타 특정 작업을 수행할 수 있는 프로세스 메서드에서 구현됩니다. 샘플 코드는 다음과 같습니다.
  2. <?php
    
    namespace AppHttpMiddleware;
    
    use Closure;
    use IlluminateHttpRequest;
    
    class MyMiddleware
    {
        /**
         * Handle an incoming request.
         *
         * @param  IlluminateHttpRequest  $request
         * @param  Closure  $next
         * @return mixed
         */
        public function handle(Request $request, Closure $next)
        {
            // 判断当前请求是否携带token
            if (!$request->header('Authorization')) {
                return response()->json(['message' => 'Unauthorized'], 401);
            }
    
            // 执行下一个中间件或应用程序
            return $next($request);
        }
    }
위 코드에서는 요청이 Authorization 헤더 정보를 전달하는지 여부를 결정하는 미들웨어 클래스를 정의합니다. 이를 전달하지 않으면 승인되지 않은 응답을 반환합니다. , Next 미들웨어 또는 애플리케이션을 실행합니다.

미들웨어 호출

Laravel 프레임워크에 미들웨어를 도입하는 방법은 매우 유연합니다. 개발자는 다양한 요청 경로, 요청 방법, 요청 유형 및 기타 조건에 대해 또는 미들웨어 그룹을 통해 다양한 미들웨어를 도입할 수 있습니다. 이를 도입하는 몇 가지 일반적인 방법은 다음과 같습니다.
  1. 전역 미들웨어 도입: app/Http/Kernel.php 파일의 $middleware 속성에 미들웨어를 추가하면 모든 요청에 ​​적용됩니다.

// app/Http/Kernel.php

protected $middleware = [
    AppHttpMiddlewareMyMiddleware::class,
];

    라우팅 미들웨어 소개: Routes/web.php 파일에 경로를 정의할 때 미들웨어 방식을 통해 지정된 미들웨어를 도입할 수 있습니다.
  • // routes/web.php
    
    use AppHttpMiddlewareMyMiddleware;
    
    Route::get('/user', function () {
        //
    })->middleware(MyMiddleware::class);
또한 미들웨어 그룹을 통해 여러 미들웨어를 일괄적으로 도입할 수도 있습니다. 이를 기반으로 미들웨어를 유연하게 적용하여 다양한 시나리오에서 다양한 기능을 구현할 수 있습니다.
  • 3. 미들웨어 실행 프로세스
Laravel 애플리케이션에 요청이 들어오면 Laravel 프레임워크는 미들웨어가 도입된 순서대로 이러한 미들웨어 클래스를 호출한 후 해당 프로세스 메서드를 실행합니다. 미들웨어 체인의 구성으로 인해 요청 처리 전후에 운영이 용이합니다.

Laravel 프레임워크의 미들웨어 스케줄링 프로세스는 다음과 같습니다.

요청이 애플리케이션에 들어가서 HttpKernel 미들웨어에 의해 처리되고 요청 객체(IlluminateHttpRequest 인스턴스)가 생성됩니다.

전역 미들웨어를 호출합니다. 실행해야 할 첫 번째 미들웨어가 있으면 해당 미들웨어의 처리 방법이 실행됩니다.

    그런 다음 라우팅 미들웨어가 호출되고, 실행해야 할 첫 번째 미들웨어가 있으면 해당 미들웨어의 처리 방법이 실행됩니다.
  1. 요청은 최종적으로 특정 비즈니스 로직 처리를 완료하기 위해 라우팅 폐쇄 기능 또는 컨트롤러 메서드에 도달합니다.
  2. 라우팅 미들웨어의 process 메소드를 통해 HttpKernel 미들웨어로 복귀하고, 라우팅 미들웨어와 글로벌 미들웨어의 종료 메소드를 역순으로 호출합니다.
  3. 마지막으로 HTTP 응답을 생성하여 브라우저에 반환합니다.
  4. Laravel 프레임워크의 미들웨어는 요청 처리 중에 특정 코드를 쉽게 실행하거나 요청을 계측하여 애플리케이션에 유연성과 보안을 추가하는 매우 유용한 기능입니다. 라라벨 미들웨어의 도입과 구현 원리를 통해 개발자는 미들웨어의 역할에 대해 더 깊이 이해하고 적용할 수 있습니다.

위 내용은 Laravel 미들웨어 구현 과정의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.