Implementierung benutzerdefinierter Middleware:
Die Middleware von Laravel bietet einen leistungsstarken Mechanismus zum Filtern von HTTP -Anforderungen, die in Ihre Anwendung eintreten. Mit dem Erstellen von benutzerdefinierten Middleware können Sie Ihre eigene Logik in den Anforderungslebenszyklus einteilen. Hier ist eine Schritt-für-Schritt-Anleitung:
php artisan make:middleware CheckAge
. Dadurch wird eine neue Middleware -Datei in app/Http/Middleware/CheckAge.php
erstellt.handle
Ihrer Middleware platzieren Sie Ihre benutzerdefinierte Logik. Diese Methode erhält eine Anfrage ( $request
) und eine Schließung ( $next
). Der Verschluss repräsentiert die nächste Middleware oder den Routenhandler. Beispiel:<code class="php"><?php namespace App\Http\Middleware; use Closure; use Illuminate\Http\Request; class CheckAge { /** * Handle an incoming request. * * @param \Illuminate\Http\Request $request * @param \Closure(\Illuminate\Http\Request): (\Illuminate\Http\Response|\Illuminate\Http\RedirectResponse) $next * @return \Illuminate\Http\Response|\Illuminate\Http\RedirectResponse */ public function handle(Request $request, Closure $next) { if ($request->age </code>
app/Http/Kernel.php
registrieren. Fügen Sie es dem $routeMiddleware
-Array hinzu:<code class="php">protected $routeMiddleware = [ // ... other middleware ... 'checkage' => \App\Http\Middleware\CheckAge::class, ];</code>
routes/web.php
oder routes/api.php
-Datei zu:<code class="php">Route::get('/profile', [ProfileController::class, 'show'])->middleware('checkage');</code>
Implementierung benutzerdefinierter Filter (Hinweis: Die Terminologie von Laravel verwendet im Allgemeinen "Middleware" anstelle von "Filtern"):
Während Laravel den Begriff "Filter" nicht explizit auf die gleiche Weise wie einige ältere Frameworks verwendet, erfüllt Middleware effektiv den gleichen Zweck. Das obige Codebeispiel zeigt ein filterähnliches Verhalten, indem das Alter überprüft und umgeleitet wird, wenn der Zustand nicht erfüllt ist. Die handle
innerhalb der Middleware fungiert als Filterfunktion.
handle
zu erstellen. Dies verbessert die Testbarkeit und die Wartbarkeit. Laravel bietet integrierte Middleware für Authentifizierung ( auth
) und Autorisierung ( auth.basic
, can
usw.). Sie können diese direkt verwenden oder benutzerdefinierte Middleware erstellen, um die Authentifizierungs-/Autorisierungslogik zu erweitern oder anzupassen.
Beispiel mit integrierten Middleware:
<code class="php">Route::get('/profile', [ProfileController::class, 'show'])->middleware('auth'); //Requires authentication Route::get('/admin', [AdminController::class, 'index'])->middleware('auth', 'admin'); //Requires authentication and admin role (assuming you have an 'admin' middleware defined)</code>
Beispiel für benutzerdefinierte Autorisierung Middleware:
<code class="php"><?php namespace App\Http\Middleware; use Closure; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; class CheckAdmin { public function handle(Request $request, Closure $next) { if (Auth::check() && Auth::user()->isAdmin()) { return $next($request); } abort(403, 'Unauthorized'); // Return 403 Forbidden if not an admin } }</code>
Denken Sie daran, dieses CheckAdmin
Middleware in Ihrer app/Http/Kernel.php
-Datei zu registrieren.
try...catch
, um Fehler anmutig zu verwalten.$routeMiddleware
-Array von app/Http/Kernel.php
korrekt registrieren. Ein häufiger Fehler besteht darin, diesen Schritt zu vergessen und die Middleware ineffektiv zu machen.Das obige ist der detaillierte Inhalt vonWie implementieren Sie benutzerdefinierte Middleware und Filter in Laravel -Anwendungen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!