Zend Framework - Routing

Mappe dei percorsi Request URIal metodo di un controller specifico. In questo capitolo vedremo come implementare le rotte in uno Zend Framework.

In generale, qualsiasi URI ha tre parti:

  • Segmento del nome host,
  • Segmento di percorso e
  • Segmento di query.

Ad esempio, in URI / URL - http://www.example.com/index?q=data, www.example.com è il segmento del nome host, index è il segmento di percorso e q=dataè il segmento di query. In genere, il routing controlla il filePage segmentcontro un insieme di vincoli. Se un vincolo corrisponde, restituisce un insieme di valori. Uno dei valori principali è il controller.

Il routing controlla anche il segmento host, il segmento di query, i metodi HTTP di richiesta, le intestazioni HTTP di richiesta, ecc. In una determinata situazione.

Route & RouteStack

Il percorso è l'oggetto principale del percorso. Zend Framework ha un'interfaccia speciale per l'oggetto percorso,RouteInterface. Tutti gli oggetti route devono implementare RouteInterface. L'elenco completo di RouteInterface è il seguente:

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 = []); 
}

Il metodo principale è match. Questo metodo di corrispondenza controlla la richiesta data rispetto al vincolo in esso definito. Se viene trovata una corrispondenza, restituisceRouteMatchoggetto. Questo oggetto RouteMatch fornisce i dettagli della richiesta abbinata come parametri. Questi parametri possono essere estratti daRouteObject usando il getParams metodo.

L'elenco completo di RouteObject è il seguente:

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); 
}

In generale, una tipica applicazione MVC ha molti percorsi. Ciascuno di questo percorso verrà elaborato in ordine LIFO e un singolo percorso verrà abbinato e restituito. Se nessun percorso viene trovato / restituito, l'applicazione restituisce l'errore "Pagina non trovata". Zend Framework fornisce un'interfaccia per elaborare i percorsi,RouteStackInterface. Questa RouteStackInterface ha la possibilità di aggiungere / rimuovere rotte.

L'elenco completo di RouteStackInterface è il seguente:

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); 
}

Il framework Zend fornisce due implementazioni di RouteStack interfaccia e sono i seguenti:

  • SimpleRouteStack
  • TreeRouteStack

Tipo di percorsi

Il framework Zend fornisce molti oggetti di route già pronti per tutte le situazioni nello spazio dei nomi "Zend \ Mvc \ Router \ Http". È sufficiente selezionare e utilizzare l'oggetto di percorso appropriato per la situazione data.

I percorsi disponibili sono i seguenti:

  • Hostname - Usato per abbinare la parte host dell'URI.

  • Literal - Utilizzato per abbinare l'URI esatto.

  • Method - Utilizzato per abbinare il metodo HTTP della richiesta in arrivo.

  • Part - Utilizzato per abbinare la parte del segmento del percorso URI utilizzando la logica personalizzata.

  • Regex - Utilizzato per abbinare il segmento del percorso URI in base al pattern Regex.

  • Schema - Utilizzato per abbinare lo schema URI come http, https, ecc.

  • Segment - Utilizzato per abbinare il percorso dell'URI suddividendolo in più segmenti.

Vediamo come scrivere il letterale e il segmento Route più comunemente usati. Le rotte sono generalmente specificate nel file di configurazione di ogni modulo -module.config.php.

Itinerario letterale

In genere, le route vengono interrogate in un ordine LIFO. Il percorso letterale serve per eseguire la corrispondenza esatta del percorso URI.

È definito come mostrato di seguito:

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

Il percorso sopra corrisponde al /path nell'URL della richiesta e restituisce index come la action e IndexController come controller.

Percorso del segmento

Un percorso segmentato viene utilizzato ogni volta che si suppone che l'URL contenga parametri variabili.

È descritto come indicato di seguito:

$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',), 
));

Qui, i segmenti sono indicati da due punti e seguiti da caratteri alfanumerici. Se si mantiene un segmento facoltativo, viene racchiuso tra parentesi. Ogni segmento può avere vincoli associati ad esso. Ogni vincolo è un'espressione regolare.

Configurazione del percorso nel modulo Tutorial

Aggiungiamo un percorso di segmento nel nostro modulo Tutorial. Aggiorna il file di configurazione del modulo tutorial -module.config.php disponibile a 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',], 
   ], 
];

Abbiamo aggiunto con successo il routing per il nostro Tutorialmodulo. Siamo solo un passo indietro nel completare il nostro modulo Tutorial. Dobbiamo aggiungereView per il nostro modulo, che impareremo nel capitolo successivo.