Dalam Laravel, middleware ialah ciri yang sangat praktikal dan penting yang mengendalikan proses antara permintaan yang memasuki aplikasi dan respons yang dikembalikan kepada klien. Semasa proses ini, anda mungkin perlu melakukan operasi pada pengguna, seperti menyemak kebenaran pengguna atau mengesahkan pengguna. Jika pengguna gagal menyemak anda, anda mungkin perlu mengubah hala pengguna ke halaman lain. Artikel ini akan memperkenalkan cara menulis middleware dalam Laravel untuk melaksanakan lompatan middleware.
1. Cipta middleware
Langkah 1: Buka terminal dan gunakan arahan Artisan Laravel untuk mencipta middleware:
php artisan make:middleware <middleware-name>
Contohnya:
php artisan make:middleware EnsureUserIsAdmin
Langkah 2: Buat middleware baharu bernama EnsureUserIsAdmin dalam direktori app/Http/Middleware. Perisian tengah ini akan menyemak sama ada pengguna semasa sudah log masuk dan pengguna mempunyai hak pentadbir.
namespace App\Http\Middleware; use Closure; use Illuminate\Http\Request; class EnsureUserIsAdmin { public function handle(Request $request, Closure $next){ if (!auth()->check() || !auth()->user()->is_admin) { return redirect('home'); } return $next($request); } }
Dalam kod di atas, kami mula-mula menggunakan fungsi auth() untuk menyemak sama ada pengguna semasa dilog masuk. Jika pengguna tidak log masuk, perisian tengah ini akan mengubah hala ke halaman utama. Jika pengguna sudah log masuk, semak sama ada pengguna mempunyai hak pentadbir. Jika pengguna tidak mempunyai hak pentadbir, perisian tengah akan mengubah hala ke halaman utama. Jika tidak, perisian tengah akan membenarkan permintaan diteruskan.
2. Menggunakan middleware
Langkah 1: Dalam fail app/Http/Kernel.php, cari tatasusunan $middlewareGroups. Tatasusunan ini mengandungi kumpulan perisian tengah yang mesti dilalui melalui aplikasi.
protected $middlewareGroups = [ 'web' => [ // ... ], 'api' => [ // ... ], ];
Langkah 2: Dalam tatasusunan $middlewareGroups di atas, nyatakan kumpulan untuk middleware baharu anda seperti berikut:
'admin' => [ \App\Http\Middleware\EnsureUserIsAdmin::class, ],
Dalam kod di atas, kami menggunakan pentadbir sebagai nama kumpulan middleware, dan nama middleware yang kami buat dalam langkah 1: EnsureUserIsAdmin.
Langkah 3: Memandangkan kami telah mencipta middleware itu sendiri dan menentukan tempat untuk menggunakannya, kami kini perlu menggunakan middleware dalam penghala kami. Buka fail route/web.php dan tentukan bahawa laluan menggunakan kumpulan middleware pentadbir, seperti yang ditunjukkan di bawah:
Route::get('admin/users', 'Admin\UserController@index')->middleware('admin');
Dalam takrif laluan di atas, kami menggunakan nama kumpulan middleware admin untuk melindungi akses kepada AdminUserController @ halaman indeks.
3. Uji perisian tengah
Akhir sekali, mulakan pelayan pembangunan anda dan uji perisian tengah baharu anda. Lawati halaman pada panel kawalan pentadbir aplikasi anda, jika anda tidak mempunyai hak pentadbir, anda harus diubah hala ke halaman utama.
Sila ambil perhatian bahawa artikel ini menunjukkan cara mencipta middleware untuk melaksanakan lompatan middleware dalam versi Laravel 5.7, ia mungkin berbeza sedikit untuk versi lain.
Ringkasan
Perisian tengah ialah fungsi yang sangat berguna dalam rangka kerja Laravel, yang boleh beroperasi dengan mudah pada pengguna dan melaksanakan lompatan perisian tengah. Dalam artikel ini, kami membincangkan cara membuat dan menggunakan perisian tengah, dan cara menggunakannya untuk melindungi halaman atau sumber tertentu. Bagi pembangun yang ingin mengukuhkan keselamatan aplikasi mereka, perisian tengah ialah alat yang sangat baik untuk mencapai matlamat ini.
Atas ialah kandungan terperinci Bagaimana untuk menulis middleware dalam laravel untuk melaksanakan lompatan middleware. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!