Was sind Richtlinien in Laravel und wie werden sie verwendet?
Jun 21, 2025 am 12:21 AMIn Laravel organisieren Richtlinien die Autorisierungslogik für Modellaktionen. 1. Richtlinien sind Klassen mit Methoden wie Ansicht, Erstellen, Aktualisierung und L?schen, die auf der Grundlage von Benutzerberechtigungen True oder False zurückgeben. 2. Um eine Richtlinie zu registrieren, müssen Sie das Modell in der Richtlinie im $ Policies -Array von AuthServiceProvider auf seine Richtlinien abgeben. 3.. Verwenden Sie Richtlinien in Controllern über die Autorize () -Methode, die eine Ausnahme ausgel?st hat, wenn der Benutzer nicht zul?ssig ist. 4.. Sie k?nnen auch die Berechtigungen anhand der CAN () -Methode direkt auf der Benutzerinstanz überprüfen oder Einschr?nkungen auf der Routenebene mithilfe von Middleware anwenden. 5. Richtlinienmethoden empfangen den authentifizierten Benutzer und optional eine Modellinstanz, die einfache oder komplexe Autorisierungsregeln wie Eigentumsüberprüfungen oder zeitbasierte Einschr?nkungen erm?glicht. Diese Struktur h?lt die Autorisierungslogik sauber, wartbar und wiederverwendbar in der Anwendung.
In Laravel sind Richtlinien eine M?glichkeit, die Autorisierungslogik in Bezug auf bestimmte Modelle zu organisieren. Stellen Sie sich sie als Gatekeeper für Ma?nahmen im Zusammenhang mit Ressourcen vor - z. B. festzustellen, ob ein Benutzer beispielsweise einen Beitrag anzeigen, aktualisieren oder l?schen kann.
Was genau sind Richtlinien?
Richtlinien in Laravel sind Klassen, die die Autorisierungslogik für ein bestimmtes Modell zusammenfassen. Jede Richtlinie enth?lt Methoden, die unterschiedlichen Aktionen entsprechen - z. B. view
, create
, update
und delete
. Diese Methoden geben entweder true
oder false
zurück und geben an, ob der derzeit authentifizierte Benutzer die angegebene Aktion auf einer bestimmten Modellinstanz ausführen darf.
Wenn Sie beispielsweise ein Post
haben, erwartet Laravel eine entsprechende PostPolicy
. Dies macht Ihren Code sauberer und wartbarer, da alle Regeln im Zusammenhang mit Beitr?gen an einem Ort zusammengefasst sind.
Sie k?nnen eine Richtlinie mit Handwerkern erstellen:
PHP Artisan Make: Policy Postpolicy -Model = Post
Wie registrieren Sie Richtlinien?
Nach dem Erstellen einer Richtlinie müssen Sie sie mit dem entsprechenden Modell in Verbindung bringen. Dies geschieht im AuthServiceProvider
, der in app/Providers/AuthServiceProvider.php
lebt.
In dieser Datei finden Sie ein $policies
-Array, in dem Sie Modelle auf ihre jeweiligen Richtlinien abbilden. Zum Beispiel:
Verwenden Sie App \ Models \ post; Verwenden Sie App \ Policies \ postpolicy; geschützte $ Policies = [ Beitrag :: class => postpolicy :: class, ];
Dies sagt Laravel, welche Richtlinie bei der Genehmigung von Aktionen im Post
verwendet werden soll.
Nach der Registrierung wird Laravel automatisch die richtige Richtlinie aufl?sen und anwenden, wenn Sie Autorisierungsmethoden wie authorize()
in einem Controller anrufen.
Verwenden von Richtlinien in Controllern
Der h?ufigste Ort für die Verwendung von Richtlinien ist innerhalb von Controllern. Wenn Sie innerhalb einer Controller -Methode arbeiten (z. B. edit
, update
oder destroy
), k?nnen Sie die authorize()
-Methode anrufen, um zu überprüfen, ob der aktuelle Benutzer die Erlaubnis zur Ausführung einer Aktion hat.
So k?nnen Sie es verwenden:
?ffentliche Funktion Update (Anfrage $ Anfrage, Post $ post) { $ this-> autorize ('update', $ post); // falls autorisiert, fahren Sie mit der Aktualisierung des Beitrags fort ... }
Wenn der Benutzer nicht autorisiert ist, wird Laravel eine AuthorizationException
veranstalten, die standardm??ig eine Antwort von 403 zurückgibt.
Alternativ k?nnen Sie die Methode can()
direkt auf dem Benutzer verwenden:
if (auth ()-> user ()-> can ('update', $ post)) { // Benutzer kann den Beitrag aktualisieren }
Oder verwenden Sie sogar Middleware, um den Zugriff auf der Routenebene einzuschr?nken:
Route :: put ('/posts/{post}', [postcontroller :: class, 'update'])-> can ('update', 'post');
Schreibpolitikmethoden
Jede Methode in einer Richtlinienklasse empf?ngt den aktuell authentifizierten Benutzer und die relevante Modellinstanz (falls zutreffend). Beispielsweise k?nnte die update
so aussehen:
?ffentliche Funktionsaktualisierung (Benutzer $ User, Post $ post) { $ user-> id === $ post-> user_id zurückgeben; }
Dies prüft, ob der authentifizierte Benutzer der Eigentümer der aktualisierten Post ist.
Einige Methoden erfordern keine Modellinstanz - wie create
, die normalerweise nur überprüfen müssen, ob der Benutzer überhaupt einen Beitrag erstellen kann:
?ffentliche Funktion erstellen (Benutzer $ user) { zurückkehren; // Erlauben Sie allen Benutzern, Beitr?ge zu erstellen }
Sie k?nnen auch eine komplexere Logik schreiben - zum Beispiel, um Aktualisierungen nur innerhalb eines bestimmten Zeitfensters zu erm?glichen:
?ffentliche Funktionsaktualisierung (Benutzer $ User, Post $ post) { $ user-> id === $ post-> user_id && now ()-> diffinhours ($ post-> erstellt_at) <24; }
Dies gibt den Benutzern ein 24-Stunden-Fenster, um ihre Beitr?ge zu bearbeiten.
Das ist die Kernidee für Richtlinien in Laravel - sie helfen, Ihre Autorisierungslogik sauber, organisiert und wiederverwendbar zu halten.
Sie sind nicht kompliziert, aber sie erfordern eine Einrichtung und Verst?ndnis dafür, wie Laravel sie behebt.
Sobald Sie den Dreh raus haben, werden sie zu einem leistungsstarken Tool, um den Zugriff in Ihrer App zu verwalten.
Das obige ist der detaillierte Inhalt vonWas sind Richtlinien in Laravel und wie werden sie verwendet?. 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)

Hei?e Themen

Einseitige Anwendungen (SPAs) k?nnen mit Laravel und Vue.js. 1) Definieren Sie die API -Routing und -Controller in Laravel, um die Datenlogik zu verarbeiten. 2) Erstellen Sie ein komponentiertes Front-End in Vue.js, um die Benutzeroberfl?che und die Dateninteraktion zu realisieren. 3) Konfigurieren Sie CORs und verwenden Sie Axios für die Dateninteraktion. 4) Verwenden Sie Vuerouter, um das Routing -Management zu implementieren und die Benutzererfahrung zu verbessern.

Zu den effizienten Methoden zum Testen von Laravel-API-Schnittstellen geh?ren: 1) Verwenden von Tools von Laravels eigenem Test-Framework und Drittanbieter wie Postman oder Schlaflosigkeit; 2) Schreiben von Unit -Tests, Funktionstests und Integrationstests; 3) Umgebungsumgebung nachahmen und den Datenbankstatus verwalten. Durch diese Schritte k?nnen die Stabilit?t und funktionale Integrit?t der API sichergestellt werden.

Die benutzerdefinierte Laravel -Benutzerauthentifizierungslogik kann in den folgenden Schritten implementiert werden: 1. Fügen Sie zus?tzliche überprüfungsbedingungen bei der Anmeldung hinzu, z. B. die überprüfung der Mailbox. 2. Erstellen Sie eine benutzerdefinierte Schutzklasse und erweitern Sie den Authentifizierungsprozess. Die benutzerdefinierte Authentifizierungslogik erfordert ein tiefes Verst?ndnis des Authentifizierungssystems von Laravel und achtet auf Sicherheit, Leistung und Wartung.

Zu den Schritten zum Erstellen eines Pakets in Laravel geh?ren: 1) Verst?ndnis der Vorteile von Paketen wie Modularit?t und Wiederverwendung; 2) nach Laravel -Namen und strukturellen Spezifikationen; 3) Erstellen eines Dienstanbieters mithilfe von Artisan Command; 4) Konfigurationsdateien korrekt ver?ffentlichen; 5) Verwaltung der Versionskontrolle und Ver?ffentlichung an Packagist; 6) strenge Tests durchführen; 7) detaillierte Dokumentation schreiben; 8) Gew?hrleistung der Kompatibilit?t mit verschiedenen Laravel -Versionen.

Die Integration von Social -Media -Anmeldungen in das Laravel -Framework kann durch die Verwendung des Laravelsocialite -Pakets erreicht werden. 1. Installieren Sie das Socialite -Paket: Verwenden Sie CompoSerRequirelaravel/Socialite. 2. Konfigurieren Sie den Dienstanbieter und Alias: Fügen Sie die relevante Konfiguration in config/app.php hinzu. 3. Setzen Sie API -Anmeldeinformationen: Konfigurieren von Social -Media -API -Anmeldeinformationen in .Env und config/dienste.php. 4. Schreiben Sie die Controller -Methode: Hinzufügen von Umleitungs- und Rückrufmethoden, um den Anmeldungsprozess für soziale Medien zu bew?ltigen. 5. FAQs handhaben: Stellen Sie die Einzigartigkeit der Benutzer, die Datensynchronisation, die Sicherheits- und Fehlerbehandlung sicher. 6. Optimierungspraxis:

Die implementierende Funktion für das Kennwortreset in Laravel erfordert die folgenden Schritte: 1. Konfigurieren Sie den E -Mail -Dienst und setzen Sie relevante Parameter in der Datei .env; 2. Definieren Sie das Zurücksetzen von Kennwortrücksetzen in Routen/web.php; 3.. Anpassen von E -Mail -Vorlagen; 4. Achten Sie auf E -Mail -Sendeprobleme und die Gültigkeitsdauer der Token und passen Sie die Konfiguration gegebenenfalls an. 5. Sicherheit in Betracht ziehen, um Brute-Force-Angriffe zu verhindern; 6. Zweiten Sie den Benutzer, nach dem Erfolg des Kennworts, den Benutzer, sich von anderen Ger?ten anzumelden.

Zu den h?ufigen Sicherheitsbedrohungen in Laravel-Anwendungen geh?ren die SQL-Injektion, Cross-Site-Scripting-Angriffe (XSS), CSRF-Cross-Site-Anfrage (CSRF) und Datei-Upload-Schwachstellen. Zu den Schutzma?nahmen geh?ren: 1.. Verwenden Sie Eloquentorm und QueryBuilder für parametrisierte Abfragen, um die SQL -Injektion zu vermeiden. 2. überprüfen und filtern Sie die Benutzereingabe, um die Sicherheit der Ausgabe zu gew?hrleisten und XSS -Angriffe zu verhindern. 3. Setzen Sie CSRF -Token in Formularen und AJAX -Anfragen, um die Anwendung vor CSRF -Angriffen zu schützen. 4. überprüfen und verarbeiten Sie die Datei -Uploads streng, um die Sicherheit der Datei sicherzustellen. 5. Es werden regelm??ige Code -Audits und Sicherheitstests durchgeführt, um potenzielle Sicherheitslücken zu entdecken und zu beheben.

Middleware ist ein Filtermechanismus in Laravel, mit dem HTTP -Anforderungen abgefangen und verarbeitet wird. Verwenden Sie Schritte: 1. Middleware: Verwenden Sie den Befehl "phpartisanMake: MiddleWareCheckrole". 2. Definieren Sie die Verarbeitungslogik: Schreiben Sie eine spezifische Logik in die generierte Datei. 3. Registrieren Sie Middleware: Middleware in kernel.php hinzufügen. 4. Verwenden Sie Middleware: Middleware in Routing Definition anwenden.
