CakePHP - रूटिंग

इस अध्याय में, हम रूटिंग से संबंधित निम्नलिखित विषयों को जानने जा रहे हैं -

  • रूटिंग का परिचय
  • कनेक्टिंग रूट
  • मार्गों के लिए तर्क पारित करना
  • पेशाब पैदा करना
  • पुन: निर्देशित करता है

रूटिंग का परिचय

इस अनुभाग में, हम देखेंगे कि आप मार्गों को कैसे कार्यान्वित कर सकते हैं, आप URL से नियंत्रक की कार्रवाई के लिए तर्क कैसे पारित कर सकते हैं, आप URL कैसे बना सकते हैं, और आप किसी विशिष्ट URL पर पुनर्निर्देशित कैसे कर सकते हैं। आम तौर पर, मार्गों को फ़ाइल में लागू किया जाता हैconfig/routes.php। रूटिंग को दो तरीकों से लागू किया जा सकता है -

  • स्थैतिक विधि
  • scoped मार्ग बिल्डर

यहाँ, दोनों प्रकारों को प्रस्तुत करने वाला एक उदाहरण है।

// Using the scoped route builder.
Router::scope('/', function ($routes) {
   $routes->connect('/', ['controller' => 'Articles', 'action' => 'index']);
});
// Using the static method.
Router::connect('/', ['controller' => 'Articles', 'action' => 'index']);

दोनों विधियों के सूचकांक विधि को निष्पादित करेगा ArticlesController। दो विधियों में से,scoped route builder बेहतर प्रदर्शन देता है।

कनेक्टिंग रूट

Router::connect()मार्गों को जोड़ने के लिए विधि का उपयोग किया जाता है। निम्नलिखित विधि का वाक्य विन्यास है -

static Cake\Routing\Router::connect($route, $defaults =[], $options =[])

के तीन तर्क हैं Router::connect() विधि -

  • पहला तर्क उस URL टेम्पलेट के लिए है जिसे आप मिलान करना चाहते हैं।

  • दूसरे तर्क में आपके मार्ग तत्वों के लिए डिफ़ॉल्ट मान हैं।

  • तीसरे तर्क में मार्ग के लिए विकल्प हैं, जिसमें आम तौर पर नियमित अभिव्यक्ति नियम शामिल हैं।

यहाँ, एक मार्ग का मूल स्वरूप है -

$routes->connect(
   'URL template',
   ['default' => 'defaultValue'],
   ['option' => 'matchingRegex']
);

उदाहरण

में बदलाव करें config/routes.php नीचे दिखाए अनुसार।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   // Register scoped middleware for in scopes.
      $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf');
   $builder->connect('/', ['controller' => 'Tests', 'action' => 'show']);
   $builder->connect('/pages/*', ['controller' => 'Pages', 'action' => 'display']);
   $builder->fallbacks();
});

बनाओ TestsController.php पर फ़ाइल करें src/Controller/TestsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/TestsController.php

<?php
declare(strict_types=1);
namespace App\Controller;
use Cake\Core\Configure;
use Cake\Http\Exception\ForbiddenException;
use Cake\Http\Exception\NotFoundException;
use Cake\Http\Response;
use Cake\View\Exception\MissingTemplateException;
class TestsController extends AppController {
   public function show()
   {
   }
}

एक फ़ोल्डर बनाएँ Tests के अंतर्गत src/Template और उस फ़ोल्डर के तहत, एक बनाएँ View fileshow.php कहा जाता है। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Tests/show.php

<h1>This is CakePHP tutorial and this is an example of connecting routes.</h1>

निम्नलिखित उदाहरण पर जाएँ निम्नलिखित URL पर जाएँ जो http: // localhost / cakephp4 / पर उपलब्ध है।

उत्पादन

उपरोक्त URL निम्न आउटपुट देगा।

तर्क पारित किया

पारित तर्क वे तर्क हैं जो URL में पारित किए जाते हैं। इन तर्कों को नियंत्रक की कार्रवाई के लिए पारित किया जा सकता है। ये पारित तर्क आपके नियंत्रक को तीन तरीकों से दिए गए हैं।

कार्रवाई विधि के तर्क के रूप में

निम्नलिखित उदाहरण से पता चलता है कि हम नियंत्रक की कार्रवाई के लिए तर्क कैसे पारित कर सकते हैं। निम्नलिखित URL पर जाएँ http: // localhost / cakephp4 / परीक्षण / value1 / value2

यह निम्नलिखित मार्ग रेखा से मेल खाएगा।

$builder->connect('tests/:arg1/:arg2', ['controller' => 'Tests', 'action' => 'show'],['pass' => ['arg1', 'arg2']]);

यहां, URL से मान 1 को आर्ग 1 को सौंपा जाएगा और मान 2 को आर्ग 2 को सौंपा जाएगा।

संख्यात्मक रूप से सरणी के रूप में

एक बार नियंत्रक की कार्रवाई के लिए तर्क पारित होने के बाद, आप निम्न कथन के साथ तर्क प्राप्त कर सकते हैं।

$args = $this->request->params[‘pass’]

नियंत्रक की कार्रवाई के लिए पारित तर्क $ args चर में संग्रहीत किया जाएगा।

रूटिंग ऐरे का उपयोग करना

तर्क को निम्नलिखित कथन द्वारा कार्रवाई के लिए भी पारित किया जा सकता है -

$routes->connect('/', ['controller' => 'Tests', 'action' => 'show',5,6]);

उपरोक्त कथन TestController के शो () विधि में दो तर्क 5, और 6 पारित करेगा।

उदाहरण

में परिवर्तन करें config/routes.php निम्न कार्यक्रम में दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
// Register scoped middleware for in scopes.
$builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf');
   $builder->connect('tests/:arg1/:arg2', ['controller' => 'Tests', 'action' => 'show'],['pass' => ['arg1', 'arg2']]);
   $builder->connect('/pages/*', ['controller' => 'Pages', 'action' => 'display']);
   $builder->fallbacks();
});

बनाओ TestsController.php पर फ़ाइल करें src/Controller/TestsController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/TestsController.php

<?php
declare(strict_types=1);
namespace App\Controller;
use Cake\Core\Configure;
use Cake\Http\Exception\ForbiddenException;
use Cake\Http\Exception\NotFoundException;
use Cake\Http\Response;
use Cake\View\Exception\MissingTemplateException;
class TestsController extends AppController {
public function show($arg1, $arg2) {
      $this->set('argument1',$arg1);
      $this->set('argument2',$arg2);
   }
}

एक फ़ोल्डर बनाएँ Tests पर src/Template और उस फ़ोल्डर के तहत एक बनाएँ Viewshow.php नामक फ़ाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Tests/show.php.

<h1>This is CakePHP tutorial and this is an example of Passed arguments.</h1>
<?php
   echo "Argument-1:".$argument1."<br/>";
   echo "Argument-2:".$argument2."<br/>";
?>

निम्नलिखित URL http: // localhost / cakephp4 / परीक्षण / विराट / कुणाल पर जाकर उपरोक्त उदाहरण देखें

उत्पादन

निष्पादन के बाद, उपरोक्त URL निम्न आउटपुट का उत्पादन करेगा।

जनरेटिंग यूआरएल

यह CakePHP की एक शांत विशेषता है। जनरेट किए गए URL का उपयोग करते हुए, हम आसानी से पूरे कोड को संशोधित किए बिना एप्लिकेशन में URL की संरचना को बदल सकते हैं।

url( string|array|null $url null , boolean $full false )

उपरोक्त समारोह में दो तर्क होंगे -

  • पहला तर्क निम्नलिखित में से किसी को निर्दिष्ट करने वाला एक सरणी है - 'controller', 'action', 'plugin'। इसके अतिरिक्त, आप रूट किए गए तत्व या क्वेरी स्ट्रिंग पैरामीटर प्रदान कर सकते हैं। यदि स्ट्रिंग है, तो इसे किसी भी मान्य यूआरएल स्ट्रिंग का नाम दिया जा सकता है।

  • यदि सही है, तो परिणाम के लिए पूर्ण आधार URL तैयार किया जाएगा। डिफ़ॉल्ट गलत है।

उदाहरण

में परिवर्तन करें config/routes.php निम्न कार्यक्रम में दिखाया गया है।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   // Register scoped middleware for in scopes.
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf');
   $builder->connect('/generate',['controller'=>'Generates','action'=>'show']);
   $builder->fallbacks();
});

बनाओ GeneratesController.php पर फ़ाइल करें src/Controller/GeneratesController.php. नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ।

src/Controller/GeneratesController.php

<?php
declare(strict_types=1);
namespace App\Controller;
21
use Cake\Core\Configure;
use Cake\Http\Exception\ForbiddenException;
use Cake\Http\Exception\NotFoundException;
use Cake\Http\Response;
use Cake\View\Exception\MissingTemplateException;
class GeneratesController extends AppController {
   public function show()
   {
   }
}

एक फ़ोल्डर बनाएँ Generates at src/Template और उस फ़ोल्डर के तहत, एक बनाएँ Viewshow.php नामक फ़ाइल। उस फ़ाइल में निम्न कोड कॉपी करें।

src/Template/Generates/show.php

<h1>This is CakePHP tutorial and this is an example of Generating URLs<h1>

निम्न URL पर जाकर उपरोक्त उदाहरण देखें -

http: // localhost / cakephp4 / उत्पन्न

उत्पादन

उपरोक्त URL निम्न आउटपुट का उत्पादन करेगा -

अनुप्रेषित रूटिंग

रीडायरेक्ट रूटिंग उपयोगी है, जब हम क्लाइंट एप्लिकेशन को सूचित करना चाहते हैं कि, यह URL ले जाया गया है। निम्नलिखित फ़ंक्शन का उपयोग करके URL को पुनर्निर्देशित किया जा सकता है -

static Cake\Routing\Router::redirect($route, $url, $options =[])

उपरोक्त समारोह के तीन तर्क इस प्रकार हैं -

  • मार्ग के खाके का वर्णन करने वाला एक तार।

  • URL को पुनर्निर्देशित करने के लिए।

  • मार्ग में नामित तत्वों को नियमित अभिव्यक्तियों से मिलान करने वाला एक सरणी जो उस तत्व से मेल खाना चाहिए।

उदाहरण

में परिवर्तन करें config/routes.phpनीचे दिखाए अनुसार। यहां, हमने उन नियंत्रकों का उपयोग किया है जो पहले बनाए गए थे।

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   // Register scoped middleware for in scopes.
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf');
   $builder->connect('/generate',['controller'=>'Generates','action'=>'show']);
   $builder->redirect('/redirect','https://tutorialspoint.com/');
   $builder->fallbacks();
});

निम्नलिखित URL पर जाकर उपरोक्त उदाहरण देखें।

URL 1 - http: // localhost / cakephp4 / generate

URL 1 के लिए आउटपुट

URL 2 - http: // localhost / cakephp4 / redirect

URL 2 के लिए आउटपुट

आपको https://tutorialspoint.com पर पुनः निर्देशित किया जाएगा