Zend 프레임 워크-라우팅

라우팅 맵 Request URI특정 컨트롤러의 방법에. 이 장에서는 Zend 프레임 워크에서 경로를 구현하는 방법을 살펴 보겠습니다.

일반적으로 모든 URI는 세 부분으로 구성됩니다.

  • 호스트 이름 세그먼트,
  • 경로 세그먼트 및
  • 쿼리 세그먼트.

예를 들어, URI / URL- http://www.example.com/index?q=data, www.example.com 호스트 이름 세그먼트입니다. index 경로 세그먼트이고 q=data쿼리 세그먼트입니다. 일반적으로 라우팅은Page segment일련의 제약에 대해. 제약 조건이 일치하면 값 집합을 반환합니다. 주요 가치 중 하나는 컨트롤러입니다.

라우팅은 또한 특정 상황에서 호스트 세그먼트, 쿼리 세그먼트, 요청 HTTP 메서드, 요청 HTTP 헤더 등을 확인합니다.

경로 및 RouteStack

Route는 라우팅의 주요 개체입니다. Zend Framework에는 경로 개체에 대한 특수 인터페이스가 있습니다.RouteInterface. 모든 경로 개체는 RouteInterface를 구현해야합니다. RouteInterface의 전체 목록은 다음과 같습니다.

namespace Zend\Mvc\Router;  
use Zend\Stdlib\RequestInterface as Request;  
interface RouteInterface { 
   public static function factory(array $options = []); public function match(Request $request); 
   public function assemble(array $params = [], array $options = []); 
}

주요 방법은 match. 이 일치 메소드는 정의 된 제한에 대해 주어진 요청을 확인합니다. 일치하는 항목이 있으면RouteMatch목적. 이 RouteMatch 객체는 일치 요청의 세부 정보를 매개 변수로 제공합니다. 이러한 매개 변수는 다음에서 추출 할 수 있습니다.RouteObject 사용 getParams 방법.

RouteObject의 전체 목록은 다음과 같습니다.

namespace Zend\Mvc\Router;  
class RouteMatch { 
   public function __construct(array $params); public function setMatchedRouteName($name); 
   public function getMatchedRouteName(); 
   public function setParam($name, $value); 
   public function getParams(); 
   public function getParam($name, $default = null); 
}

일반적으로 일반적인 MVC 응용 프로그램에는 많은 경로가 있습니다. 이 각 경로는 LIFO 순서로 처리되며 단일 경로가 일치하여 반환됩니다. 일치 / 반환 된 경로가 없으면 응용 프로그램은 "페이지를 찾을 수 없음"오류를 반환합니다. Zend Framework는 경로를 처리하는 인터페이스를 제공합니다.RouteStackInterface. 이 RouteStackInterface에는 경로를 추가 / 제거하는 옵션이 있습니다.

RouteStackInterface의 전체 목록은 다음과 같습니다.

namespace Zend\Mvc\Router;  
interface RouteStackInterface extends RouteInterface { 
   public function addRoute($name, $route, $priority = null); public function addRoutes(array $routes); 
   public function removeRoute($name); public function setRoutes(array $routes); 
}

Zend 프레임 워크는 RouteStack 인터페이스는 다음과 같습니다-

  • SimpleRouteStack
  • TreeRouteStack

경로 유형

Zend 프레임 워크는 "Zend \ Mvc \ Router \ Http"네임 스페이스 아래의 모든 상황에 대해 준비된 많은 경로 개체를 제공합니다. 주어진 상황에 맞는 경로 객체를 선택하고 사용하는 것으로 충분합니다.

사용 가능한 경로는 다음과 같습니다-

  • Hostname − URI의 호스트 부분을 일치시키는 데 사용됩니다.

  • Literal − 정확한 URI를 일치시키는 데 사용됩니다.

  • Method − 들어오는 요청의 HTTP 방식을 일치시키는 데 사용됩니다.

  • Part − 사용자 지정 논리를 사용하여 URI 경로 세그먼트의 일부를 일치시키는 데 사용됩니다.

  • Regex − 정규식 패턴으로 URI 경로 세그먼트를 일치시키는 데 사용됩니다.

  • Schema − http, https 등과 같은 URI 스키마를 일치시키는 데 사용됩니다.

  • Segment − URI 경로를 여러 세그먼트로 분할하여 일치시키는 데 사용됩니다.

가장 일반적으로 사용되는 리터럴 및 세그먼트 경로를 작성하는 방법을 살펴 보겠습니다. 경로는 일반적으로 각 모듈의 구성 파일에 지정됩니다.module.config.php.

리터럴 루트

일반적으로 경로는 LIFO 순서로 쿼리됩니다. Literal 경로는 URI 경로의 정확한 일치를 수행하기위한 것입니다.

다음과 같이 정의됩니다.

$route = Literal::factory(array( 
   'route' => '/path', 
   'defaults' => array('controller' => 'Application\Controller\IndexController', 
      'action' => 'index',), 
));

위의 경로는 /path 요청 URL 및 반환 indexactionIndexController 컨트롤러로.

구간 경로

세그먼트 경로는 URL에 변수 매개 변수가 포함되어야 할 때마다 사용됩니다.

다음과 같이 설명됩니다.

$route = Segment::factory(array( 
   'route' => '/:controller[/:action]', 
   'constraints' => array( 
      'controller' => '[a-zA-Z][a-zA-Z0-9_-]+', 
      'action' => '[a-zA-Z][a-zA-Z0-9_-]+', 
   ), 
   'defaults' => array( 
      'controller' => 'Application\Controller\IndexController', 
      'action' => 'index',), 
));

여기서 세그먼트는 콜론으로 표시되고 그 뒤에 영숫자가옵니다. 유지하는 세그먼트는 선택 사항 인 경우 대괄호로 묶입니다. 각 세그먼트에는 연관된 제약 조건이있을 수 있습니다. 각 제약은 정규식입니다.

자습서 모듈에서 경로 구성

Tutorial 모듈에 세그먼트 경로를 추가하겠습니다. 튜토리얼 모듈 구성 파일 업데이트 –module.config.php 사용 가능 myapp/module/Tutorial/config.

<?php  
namespace Tutorial;  
use Zend\ServiceManager\Factory\InvokableFactory; 
use Zend\Router\Http\Segment;  
return [ 
   'controllers' => [ 
      'factories' => [ 
         Controller\TutorialController::class => InvokableFactory::class, 
      ], 
   ], 
   'router' => [ 
      'routes' => [ 
         'tutorial' => [ 
            'type'    => Segment::class, 
               'options' => [ 
                  'route' => '/tutorial[/:action[/:id]]', 
                  'constraints' => [ 
                     'action' => '[a-zA-Z][a-zA-Z0-9_-]*', 
                     'id'     => '[0-9]+', 
                  ], 
                  'defaults' => [
                     'controller' => Controller\TutorialController::class, 
                     'action'     => 'index', 
                  ], 
               ], 
            ], 
      ], 
   ], 
   'view_manager' => [ 
      'template_path_stack' => ['tutorial' => __DIR__ . '/../view',], 
   ], 
];

우리는 라우팅을 성공적으로 추가했습니다. Tutorial기준 치수. 우리는 튜토리얼 모듈을 완료하는 데 한 걸음 뒤처졌습니다. 우리는 추가해야합니다View 우리 모듈에 대해서는 다음 장에서 배울 것입니다.