लारवेल - नियंत्रक

एमवीसी ढांचे में, 'सी' अक्षर नियंत्रक के लिए खड़ा है। यह दृश्य और मॉडल के बीच निर्देशन यातायात के रूप में कार्य करता है। इस अध्याय में, आप लारवेल में नियंत्रकों के बारे में जानेंगे।

एक नियंत्रक बनाना

आपके द्वारा उपयोग किए जा रहे ऑपरेटिंग सिस्टम के आधार पर कमांड प्रॉम्प्ट या टर्मिनल खोलें और कारीगर CLI (कमांड लाइन इंटरफ़ेस) का उपयोग करके नियंत्रक बनाने के लिए निम्न कमांड टाइप करें।

php artisan make:controller <controller-name> --plain

अपने नियंत्रक के नाम के साथ <नियंत्रक-नाम> बदलें। जैसा कि हम तर्क दे रहे हैं, इससे एक सादा निर्माण होगा -plain। यदि आप एक सादा कंस्ट्रक्टर नहीं बनाना चाहते हैं, तो आप केवल तर्क को अनदेखा कर सकते हैं। बनाए गए निर्माण को देखा जा सकता हैapp/Http/Controllers

आप देखेंगे कि कुछ बुनियादी कोडिंग आपके लिए पहले ही हो चुकी है और आप अपनी कस्टम कोडिंग जोड़ सकते हैं। निर्मित नियंत्रक को निम्नलिखित सिंटैक्स द्वारा मार्गों से कहा जा सकता है।

वाक्य - विन्यास

Route::get(‘base URI’,’controller@method’);

उदाहरण

Step 1 - बनाने के लिए निम्न कमांड निष्पादित करें UserController

php artisan make:controller UserController --plain

Step 2 - सफल निष्पादन के बाद, आप निम्न आउटपुट प्राप्त करेंगे।

Step 3 - आप बनाया नियंत्रक पर देख सकते हैं app/Http/Controller/UserController.php आपके लिए पहले से ही लिखी गई कुछ बुनियादी कोडिंग के साथ और आप अपनी जरूरत के आधार पर अपनी खुद की कोडिंग जोड़ सकते हैं।

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;

class UserController extends Controller {
   //
}

नियंत्रक मिडिलवेयर

हमने पहले मिडलवेयर देखा है और इसे कंट्रोलर के साथ भी इस्तेमाल किया जा सकता है। मिडलवेयर को कंट्रोलर के रूट या आपके कंट्रोलर के कंस्ट्रक्टर के भीतर भी सौंपा जा सकता है। कंट्रोलर को मिडिलवेयर असाइन करने के लिए आप मिडलवेयर विधि का उपयोग कर सकते हैं। पंजीकृत मिडलवेयर को कंट्रोलर की कुछ विधि तक भी सीमित रखा जा सकता है।

मार्ग के लिए मिडिलवेयर असाइन करना

Route::get('profile', [
   'middleware' => 'auth',
   'uses' => 'UserController@showProfile'
]);

यहाँ हम प्रोफाइल मार्ग में UserController को मिडिलवेयर असाइन कर रहे हैं।

कंट्रोलर के कंस्ट्रक्टर के भीतर मिडिलवेयर असाइन करना

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;

class UserController extends Controller {
   public function __construct() {
      $this->middleware('auth');
   }
}

यहां हम असाइन कर रहे हैं auth में मिडिलवेयर विधि का उपयोग कर मिडलवेयर UserController निर्माता।

उदाहरण

Step 1 - कोड की निम्नलिखित पंक्तियों को इसमें जोड़ें app/Http/routes.php फ़ाइल करें और इसे सहेजें।

routes.php

<?php
Route::get('/usercontroller/path',[
   'middleware' => 'First',
   'uses' => 'UserController@showPath'
]);

Step 2 - नामक एक मिडलवेयर बनाएं FirstMiddleware कोड की निम्नलिखित पंक्ति निष्पादित करके।

php artisan make:middleware FirstMiddleware

Step 3 - में निम्नलिखित कोड जोड़ें handle नव निर्मित FirstMiddleware की विधि app/Http/Middleware

FirstMiddleware.php

<?php

namespace App\Http\Middleware;
use Closure;

class FirstMiddleware {
   public function handle($request, Closure $next) {
      echo '<br>First Middleware';
      return $next($request);
   }
}

Step 4 - नामक एक मिडलवेयर बनाएं SecondMiddleware निम्नलिखित कमांड निष्पादित करके।

php artisan make:middleware SecondMiddleware

Step 5 - नव निर्मित SecondMiddleware के हैंडल विधि में निम्नलिखित कोड जोड़ें app/Http/Middleware

SecondMiddleware.php

<?php

namespace App\Http\Middleware;
use Closure;

class SecondMiddleware {
   public function handle($request, Closure $next) {
      echo '<br>Second Middleware';
      return $next($request);
   }
}

Step 6 - नामक एक नियंत्रक बनाएँ UserController निम्नलिखित पंक्ति निष्पादित करके।

php artisan make:controller UserController --plain

Step 7 - URL के सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -

Step 8 - निम्न कोड को कॉपी करें app/Http/UserController.php फ़ाइल।

app/Http/UserController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;

class UserController extends Controller {
   public function __construct() {
      $this->middleware('Second');
   }
   public function showPath(Request $request) {
      $uri = $request->path();
      echo '<br>URI: '.$uri;
      
      $url = $request->url();
      echo '<br>';
      
      echo 'URL: '.$url;
      $method = $request->method();
      echo '<br>';
      
      echo 'Method: '.$method;
   }
}

Step 9 - अब यदि आपने इसे अभी तक निष्पादित नहीं किया है, तो निम्न कमांड को निष्पादित करके php के आंतरिक वेब सर्वर को लॉन्च करें।

php artisan serve

Step 10 - निम्न URL पर जाएं।

http://localhost:8000/usercontroller/path

Step 11 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।

रेस्टफुल रिसोर्स कंट्रोलर्स

अक्सर आवेदन करते समय हमें प्रदर्शन करने की आवश्यकता होती है CRUD (Create, Read, Update, Delete)संचालन। लारवेल हमारे लिए इस काम को आसान बनाता है। बस एक नियंत्रक बनाएं और लारवेल स्वचालित रूप से सीआरयूडी संचालन के लिए सभी तरीके प्रदान करेगा। आप सभी विधियों के लिए एक एकल मार्ग भी पंजीकृत कर सकते हैं।

उदाहरण

Step 1 - नामक एक नियंत्रक बनाएँ MyController निम्नलिखित कमांड निष्पादित करके।

php artisan make:controller MyController

Step 2 - निम्नलिखित कोड जोड़ें

app/Http/Controllers/MyController.php फ़ाइल।

app/Http/Controllers/MyController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;

class MyController extends Controller {
   public function index() {
      echo 'index';
   }
   public function create() {
      echo 'create';
   }
   public function store(Request $request) {
      echo 'store';
   }
   public function show($id) {
      echo 'show';
   }
   public function edit($id) {
      echo 'edit';
   }
   public function update(Request $request, $id) {
      echo 'update';
   }
   public function destroy($id) {
      echo 'destroy';
   }
}

Step 3 - कोड की निम्नलिखित पंक्ति जोड़ें app/Http/routes.php फ़ाइल।

app/Http/routes.php

Route::resource('my','MyController');

Step 4- अब हम संसाधन के साथ नियंत्रक दर्ज करके MyController के सभी तरीकों को पंजीकृत कर रहे हैं। नीचे संसाधन नियंत्रक द्वारा नियंत्रित कार्यों की तालिका है।

क्रिया पथ कार्य मार्ग का नाम
प्राप्त /मेरे सूची my.index
प्राप्त / मेरी / बनाने सृजन करना my.create
पद /मेरे दुकान मेरी दुकान
प्राप्त /वाह वाह} प्रदर्शन मेरा कार्यक्रम
प्राप्त / मेरी / {मेरी} / संपादित करें संपादित करें मेरा सम्पादन
PUT / PATCH /वाह वाह} अपडेट करें my.update
हटाएँ /वाह वाह} नष्ट my.destroy

Step 5 - निम्नलिखित तालिका में दिखाए गए URL को निष्पादित करने का प्रयास करें।

यूआरएल विवरण आउटपुट छवि
http: // localhost: 8000 / मेरी MyController.php की अनुक्रमणिका विधि निष्पादित करता है सूची
http: // localhost: 8000 / मेरी / बनाने निष्पादन MyController.php की विधि बनाते हैं सृजन करना
http: // localhost: 8000 / मेरी / 1 निष्पादित MyController.php की विधि दिखाते हैं प्रदर्शन
http: // localhost: 8000 / मेरी / 1 / संपादित करें निष्पादित MyController.php की विधि संपादित करें संपादित करें

प्रभावकारी नियंत्रक

नियंत्रक नियंत्रकों आपको नियंत्रक में हर क्रिया को संभालने के लिए एक मार्ग को परिभाषित करने की अनुमति देते हैं। आप इसे path.php फ़ाइल के साथ परिभाषित कर सकते हैंRoute:controller नीचे दिखाए अनुसार विधि।

Route::controller(‘base URI’,’<class-name-of-the-controller>’);

उस क्लास के नाम के साथ <class-name-of-the-नियंत्रक> को बदलें जो आपने अपने नियंत्रक को दिया है।

कंट्रोलर की विधि का नाम HTTP क्रिया के साथ शुरू होना चाहिए जैसे कि प्राप्त करें या पोस्ट करें। यदि आप इसे प्राप्त करना शुरू करते हैं, तो यह केवल अनुरोध प्राप्त करने का काम करेगा और यदि यह पोस्ट से शुरू होता है, तो यह पोस्ट अनुरोध को संभाल लेगा। HTTP वर्ब के बाद, आप विधि को कोई भी नाम दे सकते हैं लेकिन उसे URI के शीर्षक केस संस्करण का पालन करना चाहिए।

उदाहरण

Step 1- नियंत्रक बनाने के लिए नीचे दिए गए आदेश को निष्पादित करें। हमने क्लास का नाम रखा हैImplicitController। आप अपनी पसंद का कोई भी नाम कक्षा को दे सकते हैं।

php artisan make:controller ImplicitController --plain

Step 2 - चरण 1 के सफल निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -

Step 3 - निम्न कोड को कॉपी करें

app/Http/Controllers/ImplicitController.php फ़ाइल।

app/Http/Controllers/ImplicitController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;

class ImplicitController extends Controller {
   /**
      * Responds to requests to GET /test
   */
   public function getIndex() {
      echo 'index method';
   }
   
   /**
      * Responds to requests to GET /test/show/1
   */
   public function getShow($id) {
      echo 'show method';
   }
   
   /**
      * Responds to requests to GET /test/admin-profile
   */
   public function getAdminProfile() {
      echo 'admin profile method';
   }
   
   /**
      * Responds to requests to POST /test/profile
   */
   public function postProfile() {
      echo 'profile method';
   }
}

Step 4 - निम्न पंक्ति को इसमें जोड़ें app/Http/routes.php निर्दिष्ट नियंत्रक के अनुरोधों को रूट करने के लिए फ़ाइल।

app/Http/routes.php

Route::controller('test','ImplicitController');

कंस्ट्रक्टर इंजेक्शन

Laravel सर्विस कंटेनर का उपयोग सभी Laravel नियंत्रकों को हल करने के लिए किया जाता है। नतीजतन, आप किसी भी निर्भरता को टाइप करने में सक्षम हैं जो आपके निर्माता को इसके निर्माता में आवश्यकता हो सकती है। निर्भरताएँ स्वचालित रूप से हल हो जाएंगी और नियंत्रक उदाहरण में इंजेक्ट की जाएंगी।

उदाहरण

Step 1 - निम्न कोड को इसमें जोड़ें app/Http/routes.php फ़ाइल।

app/Http/routes.php

class MyClass{
   public $foo = 'bar';
}
Route::get('/myclass','ImplicitController@index');

Step 2 - निम्न कोड को इसमें जोड़ें

app/Http/Controllers/ImplicitController.php फ़ाइल।

app/Http/Controllers/ImplicitController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;

class ImplicitController extends Controller {
   private $myclass;
   
   public function __construct(\MyClass $myclass) {
      $this->myclass = $myclass;
   }
   public function index() {
      dd($this->myclass);
   }
}

Step 3 - कंस्ट्रक्टर इंजेक्शन का परीक्षण करने के लिए निम्न URL पर जाएं।

http://localhost:8000/myclass

Step 4 - आउटपुट निम्न छवि में दिखाए गए अनुसार दिखाई देगा।

विधि इंजेक्शन

कंस्ट्रक्टर इंजेक्शन के अलावा, आप अपने नियंत्रक के एक्शन तरीकों पर निर्भरता भी टाइप कर सकते हैं।

उदाहरण

Step 1 - निम्न कोड को इसमें जोड़ें app/Http/routes.php फ़ाइल।

app/Http/routes.php

class MyClass{
   public $foo = 'bar';
}
Route::get('/myclass','ImplicitController@index');

Step 2 - निम्न कोड को इसमें जोड़ें

app/Http/Controllers/ImplicitController.php फ़ाइल।

app/Http/Controllers/ImplicitController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;

class ImplicitController extends Controller {
   public function index(\MyClass $myclass) {
      dd($myclass);
   }
}

Step 3 - कंस्ट्रक्टर इंजेक्शन का परीक्षण करने के लिए निम्न URL पर जाएं।

http://localhost:8000/myclass

यह निम्नलिखित उत्पादन का उत्पादन करेगा -