이 기사에서는 주로 PHP 미들웨어에 대한 분석을 공유하고 클로저를 반환합니다. 미들웨어는 애플리케이션에 들어오는 HTTP 요청을 필터링하기 위한 편리한 메커니즘을 제공하며 사전 미들웨어와 사후 미들웨어로 나눌 수 있습니다. 사용자 인증 여부 확인, 응답 헤더(도메인 간) 추가, 요청 로그 기록 등을 위해 일반적으로 사용됩니다.
Example
<?php // 框架核心应用层 $application = function($name) { echo "this is a {$name} application\n"; }; // 前置校验中间件 $auth = function($handler) { return function($name) use ($handler) { echo "{$name} need a auth middleware\n"; return $handler($name); }; }; // 前置过滤中间件 $filter = function($handler) { return function($name) use ($handler) { echo "{$name} need a filter middleware\n"; return $handler($name); }; }; // 后置日志中间件 $log = function($handler) { return function($name) use ($handler) { $return = $handler($name); echo "{$name} need a log middleware\n"; return $return; }; }; // 中间件栈 $stack = []; // 打包 function pack_middleware($handler, $stack) { foreach (array_reverse($stack) as $key => $middleware) { $handler = $middleware($handler); } return $handler; } // 注册中间件 // 这里用的都是全局中间件,实际应用时还可以为指定路由注册局部中间件 $stack['log'] = $log; $stack['filter'] = $filter; $stack['auth'] = $auth; $run = pack_middleware($application, $stack); $run('Laravle');출력:
Laravle에는 필터 미들웨어가 필요합니다.
Laravle에는 인증 미들웨어가 필요합니다.이것은 Laravle 애플리케이션입니다.
Laravle에는 로그 미들웨어가 필요합니다.
패키징 프로그램
미들웨어의 실행 순서는 패키징 기능(pack_middleware)에 의해 결정됩니다. 여기에 반환된 클로저는 실제로 다음과 동일합니다.
$run = $log($filter($auth($application))); $run('Laravle');사양 작성
미들웨어는 특정 요구 사항을 충족해야 합니다. 항상 클로저를 반환하고, 동일한 매개변수가 항상 클로저에 전달됩니다(메인 로직에 의해 결정됨). 클로저는 항상 핸들러의 실행 결과를 반환합니다.
미들웨어의 로직이 반환되는 경우 핸들이 완료됩니다. $handler($name)을 반환하기 전에는 사전 미들웨어이고, 그렇지 않으면 사후 미들웨어입니다.
관련 추천:
PHP 미들웨어(미들웨어) 분석
위 내용은 PHP 미들웨어 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!