लारवेल - मिडिलवेयर

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

लारवेल में एक मिडलवेयर शामिल है जो यह सत्यापित करता है कि एप्लिकेशन का उपयोगकर्ता प्रमाणित है या नहीं। यदि उपयोगकर्ता प्रमाणित है, तो यह होम पेज पर रीडायरेक्ट करता है अन्यथा, यदि नहीं, तो यह लॉगिन पेज पर रीडायरेक्ट करता है।

मिडिलवेयर निम्नलिखित कमांड को निष्पादित करके बनाया जा सकता है -

php artisan make:middleware <middleware-name>

बदलो <middleware-name>अपने मिडलवेयर के नाम के साथ। आपके द्वारा बनाए जाने वाले मिडलवेयर को देखा जा सकता हैapp/Http/Middleware निर्देशिका।

उदाहरण

मिडिलवेयर तंत्र को समझने के लिए निम्नलिखित उदाहरण देखें -

Step 1- अब हम AgeMiddleware बनाते हैं। इसे बनाने के लिए, हमें निम्नलिखित कमांड निष्पादित करने की आवश्यकता है -

php artisan make:middleware AgeMiddleware

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

Step 3 - AgeMiddleware पर बनाया जाएगा app/Http/Middleware। नई बनाई गई फ़ाइल में आपके लिए पहले से बना हुआ कोड होगा।

<?php

namespace App\Http\Middleware;
use Closure;

class AgeMiddleware {
   public function handle($request, Closure $next) {
      return $next($request);
   }
}

मिडिलवेयर का पंजीकरण

हमें इसका उपयोग करने से पहले प्रत्येक मिडलवेयर को पंजीकृत करना होगा। लारवेल में दो प्रकार के मिडलवेयर हैं।

  • ग्लोबल मिडिलवेयर
  • रूट मिडिलवेयर

Global Middleware आवेदन के हर HTTP अनुरोध पर चलेगा, जबकि Route Middlewareएक विशिष्ट मार्ग को सौंपा जाएगा। मिडलवेयर में पंजीकृत किया जा सकता हैapp/Http/Kernel.php. इस फ़ाइल में दो गुण हैं $middleware तथा $routeMiddleware$middleware प्रॉपर्टी का इस्तेमाल ग्लोबल मिडिलवेयर और रजिस्टर करने के लिए किया जाता है $routeMiddleware संपत्ति का उपयोग मार्ग विशिष्ट मिडलवेयर को पंजीकृत करने के लिए किया जाता है।

वैश्विक मिडलवेयर को पंजीकृत करने के लिए, $ मिडलवेयर संपत्ति के अंत में वर्ग को सूचीबद्ध करें।

protected $middleware = [
   \Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
   \App\Http\Middleware\EncryptCookies::class,
   \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
   \Illuminate\Session\Middleware\StartSession::class,
   \Illuminate\View\Middleware\ShareErrorsFromSession::class,
   \App\Http\Middleware\VerifyCsrfToken::class,
];

मार्ग विशिष्ट मिडिलवेयर को पंजीकृत करने के लिए, $ मार्गमाडेलवेयर संपत्ति के लिए कुंजी और मूल्य जोड़ें।

protected $routeMiddleware = [
   'auth' => \App\Http\Middleware\Authenticate::class,
   'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
   'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
];

उदाहरण

हमने बनाया है AgeMiddlewareपिछले उदाहरण में। अब हम इसे रूट विशिष्ट मिडलवेयर प्रॉपर्टी में पंजीकृत कर सकते हैं। उस पंजीकरण का कोड नीचे दिखाया गया है।

निम्नलिखित के लिए कोड है app/Http/Kernel.php -

<?php

namespace App\Http;
use Illuminate\Foundation\Http\Kernel as HttpKernel;

class Kernel extends HttpKernel {
   protected $middleware = [
      \Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
      \App\Http\Middleware\EncryptCookies::class,
      \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
      \Illuminate\Session\Middleware\StartSession::class,
      \Illuminate\View\Middleware\ShareErrorsFromSession::class,
      \App\Http\Middleware\VerifyCsrfToken::class,
   ];
  
   protected $routeMiddleware = [
      'auth' => \App\Http\Middleware\Authenticate::class,
      'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
      'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
      'Age' => \App\Http\Middleware\AgeMiddleware::class,
   ];
}

मिडलवेयर पैरामीटर्स

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

public function handle($request, Closure $next) {
   return $next($request);
}

उदाहरण

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

php artisan make:middleware RoleMiddleware

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

Step 3 - नए बनाए गए रोलमाइडलवेट के हैंडल विधि में निम्नलिखित कोड जोड़ें app/Http/Middleware/RoleMiddleware.php.

<?php

namespace App\Http\Middleware;
use Closure;

class RoleMiddleware {
   public function handle($request, Closure $next, $role) {
      echo "Role: ".$role;
      return $next($request);
   }
}

Step 4 - में रोलमेडवेयर रजिस्टर करें app\Http\Kernel.phpफ़ाइल। भूमिका फ़ाइल को हाइलाइट करने के लिए उस फ़ाइल को ग्रे कलर में हाइलाइट करें।

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

php artisan make:controller TestController --plain

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

Step 7 - कोड की निम्नलिखित पंक्तियों को कॉपी करें app/Http/TestController.php फ़ाइल।

app/Http/TestController.php

<?php

namespace App\Http\Controllers;

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

class TestController extends Controller {
   public function index() {
      echo "<br>Test Controller.";
   }
}

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

app/Http/routes.php

Route::get('role',[
   'middleware' => 'Role:editor',
   'uses' => 'TestController@index',
]);

Step 9 - मापदंडों के साथ मिडलवेयर का परीक्षण करने के लिए निम्न URL पर जाएं

http://localhost:8000/role

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

टर्मिनेबल मिडलवेयर

ब्राउज़र में प्रतिक्रिया भेजे जाने के बाद टर्मिनेबल मिडलवेयर कुछ कार्य करता है। इसके साथ एक मिडलवेयर बनाकर इसे पूरा किया जा सकता हैterminateमिडलवेयर में विधि। टर्मिनेबल मिडलवेयर को वैश्विक मिडलवेयर के साथ पंजीकृत होना चाहिए। समाप्ति की विधि को दो तर्क प्राप्त होंगे$request तथा $response. निम्न कोड में दिखाए गए अनुसार समाप्ति विधि बनाई जा सकती है।

उदाहरण

Step 1 - बनाएं TerminateMiddleware नीचे दिए गए कमांड को निष्पादित करके।

php artisan make:middleware TerminateMiddleware

Step 2 - उपरोक्त कदम निम्नलिखित उत्पादन का उत्पादन करेगा -

Step 3 - नए बनाए गए में निम्नलिखित कोड को कॉपी करें TerminateMiddleware पर app/Http/Middleware/TerminateMiddleware.php.

<?php

namespace App\Http\Middleware;
use Closure;

class TerminateMiddleware {
   public function handle($request, Closure $next) {
      echo "Executing statements of handle method of TerminateMiddleware.";
      return $next($request);
   }
   
   public function terminate($request, $response) {
      echo "<br>Executing statements of terminate method of TerminateMiddleware.";
   }
}

Step 4 - रजिस्टर करें TerminateMiddleware में app\Http\Kernel.phpफ़ाइल। TerminateMiddleware रजिस्टर करने के लिए उस फ़ाइल में ग्रे रंग में हाइलाइट की गई लाइन जोड़ें।

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

php artisan make:controller ABCController --plain

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

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

app/Http/ABCController.php

<?php

namespace App\Http\Controllers;

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

class ABCController extends Controller {
   public function index() {
      echo "<br>ABC Controller.";
   }
}

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

app/Http/routes.php

Route::get('terminate',[
   'middleware' => 'terminate',
   'uses' => 'ABCController@index',
]);

Step 9 - टर्मिनेबल मिडलवेयर का परीक्षण करने के लिए निम्न URL पर जाएं।

http://localhost:8000/terminate

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