Ketika kita sedang mengakses halaman website, mungkin kita pernah melihat pesan peringatan yang muncul ketika kita mencoba mengakses halaman tertentu. Misalnya, ketika kita melakukan login dengan menggunakan akun dengan role sebagai “customer”, namun kita mengakses halaman dashboard admin atau halaman yang hanya bisa diakses oleh akun dengan role “super admin”. Maka permintaan tersebut tidak diizinkan untuk diproses dan pesan kesalahan atau peringatan akan muncul. Hal tersebut merupakan gambaran bagaimana Middleware pada Laravel bekerja.
Fungsi Utama Middleware pada Laravel?
Middleware menjadi salah satu fitur yang sangat penting pada Laravel. Dengan Middleware kita dapat mengontrol dan memodifikasi permintaan HTTP setelah ataupun sebelum permintaan tersebut diproses oleh aplikasi Laravel kita. Sederhananya, Middleware pada Laravel layaknya seperti filter sebagai penghubung antara permintaan HTTP dengan aplikasi Laravel kita yang dapat membantu memeriksa permintaan dan menentukan apa yang harus dilakukan sebelum permintaan tersebut diproses.
Middleware memiliki beberapa fungsi utama yang diantaranya adalah sebagai berikut:
Authentication
Middleware pada Laravel dapat kita gunakan untuk melakukan Authentication (autentikasi) dimana kita dapat melakukan verifikasi terhadap pengguna aplikasi kita. Misalnya kita dapat menggunakan Middleware untuk memastikan pengguna perlu login terlebih dahulu sebelum mengakses halaman tertentu pada aplikasi Laravel kita. Laravel menyediakan Auth Middleware bawaan yang dapat kita gunakan untuk mengimplementasikan autentikasi pada aplikasi Laravel kita.
Authorization
Selanjutnya, Middleware juga dapat kita gunakan untuk melakukan Authorization (otorisasi) untuk memastikan pengguna aplikasi kita hanya dapat mengakses halaman tertentu yang sesuai dengan hak akses yang telah kita tentukan. Otorisasi biasanya digunakan untuk mengatur akses pengguna kedalam sistem aplikasi kita. Laravel juga menyediakan Middleware bawaan yaitu Gate Middleware yang dapat kita gunakan untuk mengimplementasikan otorisasi pada aplikasi Laravel kita.
Logging
Selain Authentication dan Authorization, Middleware juga dapat kita gunakan untuk melakukan Logging, yaitu mencatat permintaan HTTP dan respons yang diterima, serta mengidentifikasi masalah yang muncul pada aplikasi Laravel kita. Laravel menyediakan Log Middleware sebagai Middleware bawaan untuk mengimplementasikan Logging.
Throttling
Middleware dapat kita gunakan untuk melakukan Throttling, yaitu mengatur dan membatasi jumlah permintaan HTTP yang masuk dan diterima oleh aplikasi kita dalam jangka waktu tertentu dari satu sumber. Hal ini sangat penting dan berguna untuk mencegah serangan DDos terhadap aplikasi kita. Kita dapat menggunakan Middleware bawaan Laravel yaitu RateLimiter untuk mengimplementasikan Throttling pada aplikasi kita.
Kesimpulan
Middleware merupakan fitur yang sangat penting pada Laravel dan berguna untuk meningkatkan kinerja aplikasi kita. Kita dapat dengan mudah mengatur alur permintaan HTTP dan mengontrol akses pada fitur-fitur tertentu pada aplikasi kita. Dengan memahami fungsi-fungsi utama seperti Authentication, Authorization, Logging, dan Throttling, kita dapat mengoptimalkan penggunaan middleware di dalam aplikasi Laravel yang kita bangun.