Laravel - Middleware

Middleware bertindak sebagai jembatan antara permintaan dan tanggapan. Ini adalah jenis mekanisme penyaringan. Bab ini menjelaskan tentang mekanisme middleware di Laravel.

Laravel menyertakan middleware yang memverifikasi apakah pengguna aplikasi tersebut diautentikasi atau tidak. Jika pengguna diautentikasi, ia dialihkan ke halaman beranda sebaliknya, jika tidak, ia dialihkan ke halaman login.

Middleware dapat dibuat dengan menjalankan perintah berikut -

php artisan make:middleware <middleware-name>

Ganti <middleware-name>dengan nama middleware Anda. Middleware yang Anda buat dapat dilihat diapp/Http/Middleware direktori.

Contoh

Perhatikan contoh berikut untuk memahami mekanisme middleware -

Step 1- Sekarang mari kita buat AgeMiddleware. Untuk membuatnya, kita perlu menjalankan perintah berikut -

php artisan make:middleware AgeMiddleware

Step 2 - Setelah berhasil mengeksekusi perintah, Anda akan menerima output berikut -

Step 3 - AgeMiddleware akan dibuat pada app/Http/Middleware. File yang baru dibuat akan memiliki kode berikut yang sudah dibuat untuk Anda.

<?php

namespace App\Http\Middleware;
use Closure;

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

Mendaftarkan Middleware

Kita perlu mendaftarkan setiap middleware sebelum menggunakannya. Ada dua jenis Middleware di Laravel.

  • Middleware Global
  • Rute Middleware

Itu Global Middleware akan berjalan di setiap permintaan HTTP aplikasi, sedangkan Route Middlewareakan ditugaskan ke rute tertentu. Middleware dapat didaftarkan diapp/Http/Kernel.php. File ini berisi dua properti $middleware dan $routeMiddleware. $middleware properti digunakan untuk mendaftar Global Middleware dan $routeMiddleware properti digunakan untuk mendaftarkan middleware khusus rute.

Untuk mendaftarkan middleware global, daftarkan kelas di akhir properti $ middleware.

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,
];

Untuk mendaftarkan middleware khusus rute, tambahkan kunci dan nilai ke properti $ routeMiddleware.

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

Contoh

Kami telah menciptakan AgeMiddlewarepada contoh sebelumnya. Sekarang kita dapat mendaftarkannya di properti middleware spesifik rute. Kode untuk pendaftaran itu ditampilkan di bawah ini.

Berikut ini adalah kode untuk 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,
   ];
}

Parameter Middleware

Kita juga bisa melewatkan parameter dengan Middleware. Misalnya, jika aplikasi Anda memiliki peran berbeda seperti pengguna, admin, admin super, dll. Dan Anda ingin mengautentikasi tindakan berdasarkan peran, ini dapat dicapai dengan meneruskan parameter dengan middleware. Middleware yang kami buat berisi fungsi berikut dan kami dapat meneruskan argumen kustom kami setelah$next argumen.

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

Contoh

Step 1 - Buat RoleMiddleware dengan menjalankan perintah berikut -

php artisan make:middleware RoleMiddleware

Step 2 - Setelah eksekusi berhasil, Anda akan menerima output berikut -

Step 3 - Tambahkan kode berikut dalam metode pegangan RoleMiddlewareat yang baru dibuat 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 - Daftarkan RoleMiddleware di app\Http\Kernel.phpmengajukan. Tambahkan baris yang disorot dengan warna abu-abu di file itu untuk mendaftarkan RoleMiddleware.

Step 5 - Jalankan perintah berikut untuk membuat TestController -

php artisan make:controller TestController --plain

Step 6 - Setelah berhasil menjalankan langkah di atas, Anda akan menerima output berikut -

Step 7 - Salin baris kode berikut ke app/Http/TestController.php mengajukan.

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 - Tambahkan baris kode berikut ini app/Http/routes.php mengajukan.

app/Http/routes.php

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

Step 9 - Kunjungi URL berikut untuk menguji Middleware dengan parameter

http://localhost:8000/role

Step 10 - Outputnya akan muncul seperti yang ditunjukkan pada gambar berikut.

Middleware yang Dapat Diakhiri

Middleware yang dapat dihentikan melakukan beberapa tugas setelah respons dikirim ke browser. Ini dapat dilakukan dengan membuat middleware denganterminatemetode di middleware. Middleware yang dapat dihentikan harus terdaftar dengan middleware global. Metode terminate akan menerima dua argumen$request dan $response. Metode penghentian dapat dibuat seperti yang ditunjukkan pada kode berikut.

Contoh

Step 1 - Buat TerminateMiddleware dengan menjalankan perintah di bawah ini.

php artisan make:middleware TerminateMiddleware

Step 2 - Langkah di atas akan menghasilkan keluaran sebagai berikut -

Step 3 - Salin kode berikut yang baru dibuat TerminateMiddleware di 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 - Daftarkan TerminateMiddleware di app\Http\Kernel.phpmengajukan. Tambahkan baris yang disorot dengan warna abu-abu di file itu untuk mendaftarkan TerminateMiddleware.

Step 5 - Jalankan perintah berikut untuk membuat ABCController.

php artisan make:controller ABCController --plain

Step 6 - Setelah eksekusi URL berhasil, Anda akan menerima output berikut -

Step 7 - Salin kode berikut ke app/Http/ABCController.php mengajukan.

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 - Tambahkan baris kode berikut ini app/Http/routes.php mengajukan.

app/Http/routes.php

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

Step 9 - Kunjungi URL berikut untuk menguji Terminable Middleware.

http://localhost:8000/terminate

Step 10 - Outputnya akan muncul seperti yang ditunjukkan pada gambar berikut.