So verwenden Sie die Laravel-Middleware, um Ihre Anwendung zu sichern
Nov 03, 2023 pm 12:52 PMDa Webanwendungen immer komplexer werden, wird es immer wichtiger, die Sicherheit Ihrer Anwendungen zu schützen. Middleware in Laravel bietet eine einfache und nützliche M?glichkeit, Ihre Anwendung vor b?swilligen Angriffen zu schützen und gleichzeitig die Sicherheit Ihrer Anwendung zu erh?hen. In diesem Artikel wird erl?utert, wie Sie Middleware in Laravel verwenden, um Ihre Anwendung zu sichern, und es werden spezifische Codebeispiele bereitgestellt.
Was ist Middleware?
Middleware ist Code, der zwischen Anfragen und Antworten ausgeführt wird. Mit Middleware k?nnen Sie Anfragen zwischen Routern und Controllern transparent filtern. Sie k?nnen benutzerdefinierte Middleware erstellen und diese mit dem Router oder Controller Ihrer Anwendung verknüpfen.
Middleware soll die folgenden Probleme l?sen:
- Authentifizierung: Stellen Sie sicher, dass der Benutzer authentifiziert ist und die Berechtigung zum Zugriff auf die Anwendung hat.
- Autorisierung: Stellen Sie fest, ob der Benutzer/die Rolle berechtigt ist, die angeforderte Aktion auszuführen.
- Protokollierung: Zeichnen Sie wichtige Informationen aus Anfragen und Antworten zum Debuggen oder zur Sicherheitsüberprüfung auf.
- Caching: Anfragen und Antworten zwischenspeichern, um die Leistung zu verbessern.
- Datenübertragung: Daten von Anfragen und Antworten konvertieren/formatieren.
- Sicherheit: Stellen Sie sicher, dass Anwendungen vor Cross-Site Request Forgery (CSRF), Cross-Site Scripting (XSS) und anderen Sicherheitslücken geschützt sind.
Wie erstellt man Middleware?
Das Erstellen von Middleware in Laravel ist sehr einfach. Hier sind die Schritte zum Erstellen von Middleware:
- Erstellen Sie eine Middleware-Klasse.
Zuerst müssen Sie eine Middleware-Klasse erstellen. Sie k?nnen den Artisan-Befehl verwenden, um eine Vorlage für die Middleware zu erstellen:
php artisan make:middleware MiddlewareName
- Middleware konfigurieren
Sobald die Middleware-Klasse erstellt wurde, müssen Sie die Middleware im HTTP-Kernel Ihrer Anwendung registrieren. Diese Datei befindet sich im Verzeichnis /app/Http. Fügen Sie Ihre Middleware zum $middleware-Array hinzu.
- Middleware in Routern/Controllern verwenden
Schlie?lich k?nnen Sie Ihre benutzerdefinierte Middleware an den Router oder Controller Ihrer Anwendung anschlie?en. Mit der Middleware-Methode k?nnen Sie Middleware zu Ihrem Router/Controller hinzufügen. Zum Beispiel:
Route::get('/path', 'Controller@action') ->middleware('middlewareName');
Dadurch durchl?uft die Anfrage zuerst die Middleware, bevor sie den Controller erreicht.
Sichern Ihrer Anwendung
Da wir nun wissen, wie man Middleware erstellt, wollen wir uns damit befassen, wie Sie damit Ihre Anwendung schützen k?nnen.
- CSRF
CSRF-Angriff bezieht sich auf eine Angriffsmethode, bei der der Angreifer die Anmeldeinformationen des Opfers (Cookie oder Sitzung) verwendet, um in seinem Namen einen Vorgang abzuschlie?en. Nicht validierte Anfragen k?nnen leicht zu Sicherheitslücken führen. Diese Probleme k?nnen mithilfe des integrierten CSRF-Schutzes von Laravel leicht vermieden werden.
In Ihrer Anwendung k?nnen Sie den CSRF-Schutz im HTTP-Kern der Anwendung aktivieren. Normalerweise tun Sie Folgendes:
// 在Http/Kernel.php文件中 class Kernel extends HttpKernel { protected $middleware = [ IlluminateFoundationHttpMiddlewareCheckForMaintenanceMode::class, IlluminateFoundationHttpMiddlewareValidatePostSize::class, AppHttpMiddlewareTrimStrings::class, IlluminateFoundationHttpMiddlewareConvertEmptyStringsToNull::class, IlluminateSessionMiddlewareStartSession::class, IlluminateViewMiddlewareShareErrorsFromSession::class, AppHttpMiddlewareVerifyCsrfToken::class, ]; }
- XSS
Cross-Site-Scripting (XSS) ist ein Angriff, bei dem ein Angreifer b?sartigen JavaScript-Code im Browser des Opfers ausführt. Dies kann zur Offenlegung von Informationen, zur Einschleusung von Schadcode und zu anderen Sicherheitslücken führen. Middleware in Laravel kann Ihnen dabei helfen, den durch XSS-Angriffe verursachten Schaden zu mindern.
In Laravel k?nnen Sie HtmlPurifier oder andere Pakete von Drittanbietern verwenden, um Ihre Eingabedaten zu filtern. Hier ist ein Beispiel:
//在app/Http/Middleware/HtmlPurifier.php文件中 namespace AppHttpMiddleware; use Closure; use HTMLPurifier; class HtmlPurifier { public function handle($request, Closure $next) { $input = $this->purify($request->input()); $request->merge($input); return $next($request); } protected function purify(array $input) { $config = HTMLPurifier_Config::createDefault(); $purifier = new HTMLPurifier($config); foreach ($input as $key => $value) { $input[$key] = $purifier->purify($value); } return $input; } }
- Autorisierung
Autorisierung kann Ihnen dabei helfen, festzustellen, ob der Benutzer/die Rolle berechtigt ist, die angeforderte Aktion auszuführen. Die integrierte Autorisierung von Laravel macht dies einfach.
Zuerst müssen Sie die Autorisierungsrichtlinienklasse erstellen. Verwenden Sie den Artisan-Befehl, um eine Vorlage für diese Klasse zu generieren:
php artisan make:policy PostPolicy --model=Post
Dadurch wird eine neue PostPolicy-Klasse im Verzeichnis /app/Policies Ihrer Anwendung erstellt.
Sie müssen in Ihrem Antrag auch die Autorisierungsrichtlinie beim Dienstanbieter registrieren. Definieren Sie die Autorisierungsrichtlinie im AuthServiceProvider Ihrer Anwendung:
// 在app/Providers/AuthServiceProvider.php文件中 namespace AppProviders; use AppPost; use AppPoliciesPostPolicy; use IlluminateSupportFacadesGate; use IlluminateFoundationSupportProvidersAuthServiceProvider as ServiceProvider; class AuthServiceProvider extends ServiceProvider { protected $policies = [ Post::class => PostPolicy::class, ]; // 注冊(cè)策略 public function boot() { $this->registerPolicies(); } }
Als N?chstes müssen Sie die Autorisierungsmethode von Laravel in Ihrem Controller verwenden, um zu überprüfen, ob der Benutzer die Berechtigung zum Ausführen der angeforderten Aktion hat. Beispiel:
public function update(Request $request, Post $post) { $this->authorize('update', $post); // 只有具備操作權(quán)限的用戶才能看到以下內(nèi)容 return view('posts.update', [ 'post' => $post ]); }
Nach der Autorisierung k?nnen nur Benutzer/Rollen, die gem?? der Autorisierungsrichtlinie zugelassen sind, die Ansicht ?posts.update“ anzeigen.
Zusammenfassung
Middleware in Laravel ist ein leistungsstarkes Sicherheitstool, das Entwicklern dabei helfen kann, Anwendungen schnell und einfach vor CSRF, XSS und anderen Sicherheitslücken zu schützen. Dieser Artikel enth?lt konkrete Codebeispiele, die zeigen, wie Sie Middleware zum Schutz Ihrer Anwendung verwenden. Wenn Sie noch nicht damit begonnen haben, Middleware zum Schutz Ihrer Anwendungen zu verwenden, ist es jetzt an der Zeit, damit zu beginnen.
Das obige ist der detaillierte Inhalt vonSo verwenden Sie die Laravel-Middleware, um Ihre Anwendung zu sichern. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

Hei?er Artikel

Hei?e Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Es gibt drei Hauptmethoden, um Umgebungsvariablen in PHP festzulegen: 1. Globale Konfiguration über php.ini; 2. durch einen Webserver (z. B. SetEnv von Apache oder FastCGI_Param von Nginx); 3. Verwenden Sie die Funktion Putenv () in PHP -Skripten. Unter ihnen eignet sich Php.ini für globale und selten ?ndernde Konfigurationen. Die Webserverkonfiguration eignet sich für Szenarien, die isoliert werden müssen, und Putenv () ist für tempor?re Variablen geeignet. Die Persistenz -Richtlinien umfassen Konfigurationsdateien (z. B. Php.ini oder Webserverkonfiguration), .env -Dateien werden mit der DOTENV -Bibliothek und dynamische Injektion von Variablen in CI/CD -Prozessen geladen. Sicherheitsmanagement sensible Informationen sollten hart codiert werden, und es wird empfohlen.

Der Konfigurations -Cache von Laravel verbessert die Leistung, indem alle Konfigurationsdateien in eine einzelne Cache -Datei zusammengeführt werden. Das Aktivieren von Konfigurations -Cache in einer Produktionsumgebung kann die E/A -Vorg?nge reduzieren und die Analyse bei jeder Anforderung an die Datei -Analyse beschleunigen, wodurch das Laden der Konfiguration beschleunigt wird. 1. Es sollte aktiviert werden, wenn die Anwendung bereitgestellt wird, die Konfiguration stabil ist und keine h?ufigen ?nderungen erforderlich sind. 2. Nachdem Sie die Konfiguration ?ndern k?nnen, müssen Sie PhPartiSanconFig: Cache erneut ausführen, um wirksam zu werden. 3. Vermeiden Sie die Verwendung dynamischer Logik oder Verschluss, die von Laufzeitbedingungen in der Konfigurationsdatei abh?ngen. 4. Bei Problembehebungsproblemen sollten Sie zuerst den Cache l?schen, die .env-Variablen und den Umrand-Cache überprüfen.

Um PHP -Container zur Unterstützung der automatischen Konstruktion zu erm?glichen, liegt der Kern in der Konfiguration des Continuous Integration (CI) -Prozesses. 1. Verwenden Sie Dockerfile, um die PHP -Umgebung zu definieren, einschlie?lich grundlegender Bild-, Erweiterungsinstallations-, Abh?ngigkeitsmanagement- und Berechtigungseinstellungen. 2. Konfigurieren Sie CI/CD-Tools wie GitLabci und definieren Sie die Erstell-, Test- und Bereitstellungsstadien über die Datei .gitlab-ci.yml, um automatische Konstruktion, Test und Bereitstellung zu erreichen. 3.. Integrieren Sie Testframeworks wie Phpunit, um sicherzustellen, dass die Tests automatisch nach Code?nderungen ausgeführt werden. 4. Verwenden Sie automatisierte Bereitstellungsstrategien wie Kubernetes, um die Bereitstellungskonfiguration durch die Datei bereitzustellen. 5. Dockerfile optimieren und mehrstufige Konstruktionen übernehmen

Das Benutzerbereitungsmanagement ist der Kernmechanismus für die Realisierung der Produktmonetarisierung bei der PHP -Entwicklung. Es trennt Benutzer, Rollen und Berechtigungen über ein rollenbasiertes RBAC-Modell (Rollenbasis Based Access Control), um eine flexible Berechtigungszuweisung und -verwaltung zu erzielen. Die spezifischen Schritte umfassen: 1. Entwerfen Sie drei Tabellen von Benutzern, Rollen und Berechtigungen sowie zwei Zwischentabellen von User_Roles und Rollen -Lernmerkmalen; 2. Implementieren Sie die Methoden zur überprüfung von Berechtigungen im Code wie $ user-> can ('edit_post'); 3.. Verwenden Sie Cache, um die Leistung zu verbessern. 4.. Verwenden Sie die Berechtigungsregelung, um die Produktfunktionsschicht- und differenzierte Dienste zu realisieren, wodurch die Mitgliedschaftssystem- und Preisstrategien unterstützt werden. 5. Vermeiden Sie die Erlaubnis, dass die Granularit?t zu grob oder zu gut ist, und verwenden Sie "Investitionen"

Laravels EloquentsCopes ist ein Tool, das die gemeinsame Abfragelogik in lokalem Umfang und globalem Umfang unterteilt. 1. Der lokale Bereich ist mit einer Methode definiert, die mit dem Umfang beginnt und muss explizit aufgerufen werden, z. B. Post :: ver?ffentlicht (); 2. Der globale Umfang wird automatisch auf alle Abfragen angewendet, h?ufig für Soft-L?schen oder Multi-Mieter-Systeme verwendet, und die Umfangsschnittstelle muss im Modell implementiert und registriert werden. 3. Das Zielfernrohr kann mit Parametern ausgestattet werden, z. B. nach Jahr oder Monat die Filterartikel, und entsprechende Parameter werden beim Aufrufen übergeben. 4. Achten Sie auf Namensschwerpunkte, Kettenaufrufe, vorübergehende Deaktivieren und Kombinationserweiterung, um die Klarheit und Wiederverwendbarkeit von Code zu verbessern.

CreateAhelpers.phpfileinapp/helpers withcustomfunctionssformatprice, isactiveroute, andisadmin.2.addtheFiletothe "Dateien" AbschnittOfComposer

W?hlen Sie die Protokollierungsmethode aus: In der frühen Phase k?nnen Sie den integrierten Fehler () für PHP verwenden. Wechseln Sie nach der Erweiterung des Projekts auf reife Bibliotheken wie Monolog, unterstützen Sie mehrere Handler und Protokollebenen und stellen Sie sicher, dass das Protokoll Zeitstempel, Ebenen, Dateizeilennummern und Fehlerdetails enth?lt. 2. Entwurfsstruktur: Eine kleine Menge an Protokollen kann in Dateien gespeichert werden. Wenn eine gro?e Anzahl von Protokollen vorhanden ist, w?hlen Sie eine Datenbank, wenn eine gro?e Anzahl von Analysen vorhanden ist. Verwenden Sie MySQL/Postgresql zu strukturierten Daten. Elasticsearch Kibana wird für semi-strukturierte/unstrukturierte empfohlen. Gleichzeitig wird es für Backup- und regelm??ige Reinigungsstrategien formuliert. 3. Entwicklungs- und Analyseschnittstelle: Sie sollten Such-, Filter-, Aggregations- und Visualisierungsfunktionen haben. Es kann direkt in Kibana integriert werden oder die PHP-Framework-Diagrammbibliothek zur Entwicklung der Selbstentwicklung verwenden und sich auf die Einfachheit und einfache Schnittstelle konzentrieren.

Erstellen Sie Referenzen Tabelle, um Empfehlungsbeziehungen zu erfassen, einschlie?lich Empfehlungen, Empfehlungen, Empfehlungscodes und Nutzungszeit; 2. Definieren Sie die Beziehungen zwischen H?rern und Hasmany im Benutzermodell, um Empfehlungsdaten zu verwalten. 3. Erstellen Sie bei der Registrierung einen eindeutigen Empfehlungscode (kann durch Modellereignisse implementiert werden). 4. Erfassen Sie den Empfehlungscode, indem Sie die Parameter w?hrend der Registrierung abfragen, nach überprüfung eine Empfehlungsbeziehung aufstellen und die Selbstverantwortung verhindern. 5. den Belohnungsmechanismus ausl?sen, wenn empfohlene Benutzer das angegebene Verhalten (Abonnementauftrag) abschlie?en; 6. Generieren Sie gemeinsame Empfehlungsverbindungen und verwenden Sie URLs mit Laravel Signature, um die Sicherheit zu verbessern. 7. Empfehlungsstatistiken auf dem Dashboard anzeigen, z. B. die Gesamtzahl der Empfehlungen und konvertierten Zahlen; Es ist notwendig, sicherzustellen, dass Datenbankbeschr?nkungen, Sitzungen oder Cookies bestehen bleiben.
