Zend Framework - Perutean

Peta perutean Request URIke metode pengontrol tertentu. Pada bab ini, kita akan melihat bagaimana mengimplementasikan rute dalam Zend Framework.

Secara umum, setiap URI memiliki tiga bagian -

  • Segmen nama host,
  • Segmen jalur, dan
  • Segmen kueri.

Misalnya, di URI / URL - http://www.example.com/index?q=data, www.example.com adalah Segmen Nama Inang, index adalah Segmen Jalan dan q=dataadalah Segmen Kueri. Umumnya, routing memeriksa filePage segmentterhadap satu set kendala. Jika ada batasan yang cocok, maka itu mengembalikan satu set nilai. Salah satu nilai utamanya adalah pengontrol.

Routing juga memeriksa segmen host, segmen query, metode HTTP permintaan, header HTTP permintaan, dll., Dalam situasi tertentu.

Route & RouteStack

Rute adalah objek utama dalam perutean. Zend Framework memiliki antarmuka khusus untuk objek rute,RouteInterface. Semua objek rute perlu mengimplementasikan RouteInterface. Daftar lengkap RouteInterface adalah sebagai berikut -

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

Metode utamanya adalah match. Metode pencocokan ini memeriksa permintaan yang diberikan terhadap batasan yang ditentukan di dalamnya. Jika ada kecocokan yang ditemukan, itu mengembalikanRouteMatchobyek. Objek RouteMatch ini memberikan detail permintaan yang cocok sebagai parameter. Parameter ini dapat diekstraksi dariRouteObject menggunakan getParams metode.

Daftar lengkap RouteObject adalah sebagai berikut -

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

Secara umum, aplikasi MVC memiliki banyak rute. Setiap rute ini akan diproses dalam urutan LIFO dan satu rute akan dicocokkan dan dikembalikan. Jika tidak ada rute yang cocok / dikembalikan, maka aplikasi mengembalikan kesalahan "Halaman tidak ditemukan". Zend Framework menyediakan antarmuka untuk memproses rute,RouteStackInterface. RouteStackInterface ini memiliki opsi untuk menambah / menghapus rute.

Daftar lengkap RouteStackInterface adalah sebagai berikut -

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 framework menyediakan dua implementasi dari RouteStack antarmuka dan mereka adalah sebagai berikut -

  • SimpleRouteStack
  • TreeRouteStack

Jenis Rute

Zend framework menyediakan banyak objek rute yang sudah jadi untuk semua situasi di bawah namespace "Zend \ Mvc \ Router \ Http". Cukup memilih dan menggunakan objek rute yang tepat untuk situasi tertentu.

Rute yang tersedia adalah sebagai berikut -

  • Hostname - Digunakan untuk mencocokkan bagian host dari URI.

  • Literal - Digunakan untuk mencocokkan URI persis.

  • Method - Digunakan untuk mencocokkan metode HTTP dari permintaan yang masuk.

  • Part - Digunakan untuk mencocokkan bagian segmen jalur URI menggunakan logika khusus.

  • Regex - Digunakan untuk mencocokkan segmen jalur URI menurut Pola Regex.

  • Schema - Digunakan untuk mencocokkan Skema URI seperti http, https, dll.

  • Segment - Digunakan untuk mencocokkan jalur URI dengan membaginya menjadi beberapa segmen.

Mari kita lihat bagaimana menulis Rute literal dan segmen yang paling umum digunakan. Rute biasanya ditentukan dalam file konfigurasi setiap modul -module.config.php.

Rute Literal

Biasanya, rute dikueri dalam urutan LIFO. Rute literal adalah untuk melakukan pencocokan tepat dari jalur URI.

Ini didefinisikan seperti yang ditunjukkan di bawah ini -

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

Rute di atas cocok dengan /path di url permintaan dan kembali index sebagai action dan IndexController sebagai pengontrol.

Rute Segmen

Rute tersegmentasi digunakan kapan pun url Anda seharusnya berisi parameter variabel.

Ini dijelaskan seperti yang diberikan di bawah ini -

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

Di sini, Segmen dilambangkan dengan titik dua dan diikuti dengan karakter alfanumerik. Jika Anda mempertahankan segmen adalah opsional maka itu diapit oleh tanda kurung. Setiap segmen mungkin memiliki batasan yang terkait dengannya. Setiap batasan adalah ekspresi reguler.

Konfigurasi Rute di Modul Tutorial

Mari kita tambahkan rute segmen dalam modul Tutorial kita. Perbarui file konfigurasi modul tutorial -module.config.php Tersedia di 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',], 
   ], 
];

Kami telah berhasil menambahkan perutean untuk kami Tutorialmodul. Kami hanya satu langkah di belakang dalam menyelesaikan modul Tutorial kami. Kami perlu menambahkanView untuk modul kita, yang akan kita pelajari di bab selanjutnya.