Inhaltsverzeichnis
Guard in Laravel
Heim PHP-Framework Laravel Was ist Guard in Laravel?

Was ist Guard in Laravel?

Jun 02, 2022 pm 05:54 PM
laravel

In Laravel ist Guard ein Plug-in zur Benutzerauthentifizierung. Die Rolle des Guard besteht darin, die Authentifizierung zu verarbeiten und jede Anfrage zu beurteilen, Daten aus der Datenbank zu lesen und sie mit Benutzereingaben zu vergleichen und festzustellen, ob sich der Benutzer angemeldet hat oder dies zugelassen hat pass und Guard Es kann sehr flexibel sein, ein eigenes Zertifizierungssystem aufzubauen.

Was ist Guard in Laravel?

Die Betriebsumgebung dieses Artikels: Windows 10-System, Laravel Version 5.4, Dell G3-Computer.

Guard in Laravel

Tatsächlich können Sie verstehen, ob es sich um Guard oder Provide handelt. Ein Plug-In für eine bestimmte Funktion.

Seine Aufgabe besteht darin, eine Authentifizierung zu verarbeiten, um festzustellen, ob jede Anfrage oder jeder Anruf angemeldet wurde oder passieren darf.

Was ist Guard? Im Laravel/Lumen-Framework ist die Benutzeranmeldung/-registrierung die Authentifizierung Grundsätzlich verpackt und sofort einsatzbereit. Der Kern der Anmelde-/Registrierungsauthentifizierung besteht aus: Die Registrierungsinformationen des Benutzers werden in der Datenbank gespeichert (Registrierung)

Daten aus der Datenbank lesen und mit Benutzereingaben vergleichen (Authentifizierung)

Die beiden oben genannten Schritte sind die Grundlagen der Anmeldung /Registrierung. Die unterste Ebene des zweistufigen Frameworks wurde bereits für uns erstellt und viele Situationen wurden nicht berücksichtigt Benutzertabelle, aber admin_user, das Authentifizierungsfeld ist Telefon statt E-Mail usw. Einige Probleme werden durch Guard gelöst, Sie können angeben, welche Datentabelle und Felder verwendet werden sollen usw. Guard kann Ihr eigenes Authentifizierungssystem sehr flexibel erstellen.

Laienhaft ausgedrückt ist es so: Der Wachmann ist wie der Pförtner einer Gemeinschaft, kalt und rücksichtslos, er erkennt keine Menschen, er erkennt nur Registrierungsinformationen.

Der Onkel muss Ihre Identität überprüfen, bevor Sie die Community betreten. Wenn die Überprüfung fehlschlägt, lässt der Onkel Sie nicht ein.

Wenn Sie zu Fuß/mit dem Fahrrad hineingehen, muss Onkel 1 Ihre Zugangskarte überprüfen. Er holt das Buch heraus, in dem die Zugangskarteninformationen aller Eigentümer in der Gemeinde verzeichnet sind, um zu sehen, ob Ihre Zugangskarteninformationen in diesem Buch enthalten sind Wenn Sie mit dem Auto hineingehen, überprüft Onkel 2 Ihr Nummernschild aus dem Buch, in dem die Nummernschilder aller Eigentümer verzeichnet sind. Wenn der neue Eigentümer in die Gemeinde einzieht, muss er daher die Türsteher über Ihren Zugang informieren Karteninformationen oder Kfz-Kennzeichen, sonst lässt dich Onkel 2 nicht rein.

Wenn der Hausverwalter die Gemeinschaft betreten möchte, erkennt der Portier-Onkel 3 nur die Registrierungsinformationen. Der Manager zeigt seine Manager-Zugangskarte und der Portier-Onkel überprüft das Buch, in dem die Zugangskarteninformationen des Managers aufgezeichnet sind.

Das Obige entspricht der Mehrbenutzer-Authentifizierung im Rahmen:

Wanderer/Radfahrer-> Zugangskarte

Fahrer-> Zugangskarte

Zugangskontrollkarten Kennzeichen sind unterschiedliche Authentifizierungsmethoden, und das Buch, das sich der Wachmann angesehen hat, entspricht den Benutzerinformationen in verschiedenen Datenbanken. Ist es auf diese Weise nicht einfacher zu verstehen?

Lumen/Laravel bietet eine sehr flexible Authentifizierung in Form von Middleware, und mehrere Authentifizierungen können durch einfache Konfiguration umgeschaltet werden.

Das Workflow-Diagramm sieht wie folgt aus:

Wie Sie auf dem Bild sehen können, besteht ein Guard aus drei Teilen, nämlich:


Guard-Implementierung selbst

Was ist Guard in Laravel?

Benutzer-Provider-Benutzer-Provider, geben Sie an, welcher Wie wird die Datentabelle abgerufen (eloquent/Datenbank)? dass er sollte Es ist so etwas wie die Benutzerauthentifizierung.

    Es gibt Parameter zum Konfigurieren von Guards in config/auth.php. Es ist ersichtlich, dass Web und API zwei Guards sind.
  • Im normalen Geschäftsbetrieb ist die API möglicherweise eher eine Aufgabe eines Front-End-Benutzers, während das Web eher eine Aufgabe eines Back-End-Benutzers ist.

  • Die Standardkonfiguration verweist auf den Anbieter der Benutzer.
  • /*
        | Authentication Guards
        |认证关卡
        | Next, you may define every authentication guard for your application. Of course, a great default configuration has been defined for you here which uses session storage and the Eloquent user provider.
        |接下来,你可能要为你的应用定义每个认证关卡。当然,已经为你定一了一个很不错的默认配置。这里会使用会话储存和用户模型
        | All authentication drivers have a user provider. This defines how the users are actually retrieved out of your database or other storage mechanisms used by this application to persist your user's data.
        |所有的认证驱动都有一个用户提供者。这里定义了怎么实际上怎么从你的数据库或者其他储存机制中取出用户。以便应用开保持你的用户数据
        | Supported: "session", "token"
        |可选驱动:"session", "token"
        */
    'guards' => [
            'web' => [
                'driver' => 'session',
                'provider' => 'users',
            ],
            'api' => [
                'driver' => 'token',
                'provider' => 'users',
            ],
        ],
    Nach dem Login kopieren

    Als nächstes schauen wir uns an, welche Konfiguration der Anbieter hat.

      /*
        | User Providers
        |用户提供者
        | If you have multiple user tables or models you may configure multiple sources which represent each model / table. These sources may then be assigned to any extra authentication guards you have defined.
        | 如果你有多个用户表或用户模型,你可以配置多个代表用户表或模型的资源。这些资源可能被分配给应用中你定义的其他认证关卡
        | Supported: "database", "eloquent"
        |
        */
     'providers' => [
            'users' => [
                'driver' => 'eloquent',
                'model' => App\User::class,
            ],
            // 'users' => [
            //     'driver' => 'database',
            //     'table' => 'users',
            // ],
        ],
    Nach dem Login kopieren
  • Haben Sie die Benutzerkonfiguration, die Sie gerade bei Providern gesehen haben? Dies ist die Benutzergruppe für die Konfiguration von Laravel, da Front-End- und Back-End-Benutzer unter normalen Umständen getrennt arbeiten. Sie können hier also eine neue Admin-Benutzergruppe erstellen und diese konfigurieren. Standardmäßig wird nur „Benutzer“ verwendet.
  • Dementsprechend sollten die Passwortvorgänge für jede Benutzergruppe unterschiedlich sein, daher gibt es hier auch eine Passwortkonfiguration.

      /*
        | Resetting Passwords
        | 密码重置
        | You may specify multiple password reset configurations if you have more than one user table or model in the application and you want to have separate password reset settings based on the specific user types.
        | 如果你有多个用户模型或表,并且想对不同用户类型有特定的密码重置,则可以配置多个特定的重置密码
        | The expire time is the number of minutes that the reset token should be considered valid. This security feature keeps tokens short-lived so they have less time to be guessed. You may change this as needed.
        |这个获取时间是令牌过期的分钟数,这个安全措施可以保证令牌保持段时间有效,因此有更少的时间被破解。你可以按照需要更改。
        */
        'passwords' => [
            'users' => [
                'provider' => 'users',
                'table' => 'password_resets',
                'expire' => 60,
            ],
        ],
    Nach dem Login kopieren
  • Wir verwenden normalerweise Auth::check(), um angemeldete Benutzer zu erkennen oder ob der Benutzer angemeldet ist. Dies liegt daran, dass bei Verwendung der Standardkonfiguration Guard automatisch als Benutzergruppe des Benutzers konfiguriert wird.
  /*
    | Authentication Defaults
    | 默认认证配置
    | This option controls the default authentication "guard" and password reset options for your application. You may change these defaults as required, but they're a perfect start for most applications.
    | 这个就是应用的默认认证关卡个重置密码,你可以按自己要求更改。但这是最适合一个新应用的配置
    */
    'defaults' => [
        'guard' => 'web',
        'passwords' => 'users',
    ],
Nach dem Login kopieren

Web Guard verweist auf das Benutzermodell. Aber wie kann man überprüfen, ob wir zwei Benutzergruppen haben, vorne und hinten? Auth::check() ist eine Methode, um festzustellen, ob der Benutzer angemeldet ist. Wenn das Standardbenutzersystem verwendet wird, ist die Verwendung auf diese Weise kein Problem.

Wenn Sie jedoch zwei Benutzergruppen verwenden, sollten Sie folgendermaßen vorgehen:

Auth::guard('api')->check() wird verwendet, um festzustellen, ob der Front-End-Benutzer angemeldet ist. Auth: :guard('web')-> ;check() wird verwendet, um festzustellen, ob der Hintergrundbenutzer angemeldet ist

Wenn Sie also eine nicht standardmäßige Benutzergruppe verwenden, müssen Sie diese mit Guard angeben.

Was wir also normalerweise verwenden, ist die Standardkonfiguration, um sie vollständig aufzuschreiben: Auth::guard(‘web)->check()

[Verwandte Empfehlung: Laravel-Video-Tutorial]

Das obige ist der detaillierte Inhalt vonWas ist Guard in Laravel?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Vergleich der neuesten Versionen von Laravel und CodeIgniter Vergleich der neuesten Versionen von Laravel und CodeIgniter Jun 05, 2024 pm 05:29 PM

Die neuesten Versionen von Laravel 9 und CodeIgniter 4 bieten aktualisierte Funktionen und Verbesserungen. Laravel9 übernimmt die MVC-Architektur und bietet Funktionen wie Datenbankmigration, Authentifizierung und Template-Engine. CodeIgniter4 nutzt die HMVC-Architektur, um Routing, ORM und Caching bereitzustellen. In Bezug auf die Leistung sorgen das auf Dienstanbietern basierende Designmuster von Laravel9 und das leichte Framework von CodeIgniter4 für eine hervorragende Leistung. In praktischen Anwendungen eignet sich Laravel9 für komplexe Projekte, die Flexibilität und leistungsstarke Funktionen erfordern, während CodeIgniter4 für schnelle Entwicklung und kleine Anwendungen geeignet ist.

Wie vergleichen sich die Datenverarbeitungsfunktionen in Laravel und CodeIgniter? Wie vergleichen sich die Datenverarbeitungsfunktionen in Laravel und CodeIgniter? Jun 01, 2024 pm 01:34 PM

Vergleichen Sie die Datenverarbeitungsfunktionen von Laravel und CodeIgniter: ORM: Laravel verwendet EloquentORM, das eine relationale Klassen-Objekt-Zuordnung bereitstellt, während CodeIgniter ActiveRecord verwendet, um das Datenbankmodell als Unterklasse von PHP-Klassen darzustellen. Abfrage-Builder: Laravel verfügt über eine flexible verkettete Abfrage-API, während der Abfrage-Builder von CodeIgniter einfacher und Array-basiert ist. Datenvalidierung: Laravel bietet eine Validator-Klasse, die benutzerdefinierte Validierungsregeln unterstützt, während CodeIgniter über weniger integrierte Validierungsfunktionen verfügt und eine manuelle Codierung benutzerdefinierter Regeln erfordert. Praxisfall: Beispiel einer Benutzerregistrierung zeigt Lar

Was ist einsteigerfreundlicher: Laravel oder CodeIgniter? Was ist einsteigerfreundlicher: Laravel oder CodeIgniter? Jun 05, 2024 pm 07:50 PM

Für Anfänger bietet CodeIgniter eine sanftere Lernkurve und weniger Funktionen, deckt aber die Grundbedürfnisse ab. Laravel bietet einen größeren Funktionsumfang, weist jedoch eine etwas steilere Lernkurve auf. In Bezug auf die Leistung schneiden sowohl Laravel als auch CodeIgniter gut ab. Laravel verfügt über eine umfangreichere Dokumentation und aktive Community-Unterstützung, während CodeIgniter einfacher und leichtgewichtiger ist und über starke Sicherheitsfunktionen verfügt. Im praktischen Fall der Erstellung einer Blogging-Anwendung vereinfacht EloquentORM von Laravel die Datenmanipulation, während CodeIgniter mehr manuelle Konfiguration erfordert.

Laravel vs CodeIgniter: Welches Framework ist besser für große Projekte? Laravel vs CodeIgniter: Welches Framework ist besser für große Projekte? Jun 04, 2024 am 09:09 AM

Bei der Auswahl eines Frameworks für große Projekte haben Laravel und CodeIgniter jeweils ihre eigenen Vorteile. Laravel ist für Anwendungen auf Unternehmensebene konzipiert und bietet modularen Aufbau, Abhängigkeitsinjektion und einen leistungsstarken Funktionsumfang. CodeIgniter ist ein leichtes Framework, das sich eher für kleine bis mittelgroße Projekte eignet und Wert auf Geschwindigkeit und Benutzerfreundlichkeit legt. Für große Projekte mit komplexen Anforderungen und einer großen Anzahl von Benutzern sind die Leistung und Skalierbarkeit von Laravel besser geeignet. Für einfache Projekte oder Situationen mit begrenzten Ressourcen sind die leichten und schnellen Entwicklungsfunktionen von CodeIgniter idealer.

Laravel – Handwerkerbefehle Laravel – Handwerkerbefehle Aug 27, 2024 am 10:51 AM

Laravel – Artisan Commands – Laravel 5.7 bietet eine neue Möglichkeit, neue Befehle zu behandeln und zu testen. Es enthält eine neue Funktion zum Testen von Handwerkerbefehlen und die Demonstration wird unten erwähnt?

Laravel vs CodeIgniter: Welches Framework ist besser für kleine Projekte? Laravel vs CodeIgniter: Welches Framework ist besser für kleine Projekte? Jun 04, 2024 pm 05:29 PM

Für kleine Projekte eignet sich Laravel, für größere Projekte, die starke Funktionalität und Sicherheit erfordern. CodeIgniter eignet sich für sehr kleine Projekte, die geringes Gewicht und Benutzerfreundlichkeit erfordern.

Welche ist die bessere Template-Engine, Laravel oder CodeIgniter? Welche ist die bessere Template-Engine, Laravel oder CodeIgniter? Jun 03, 2024 am 11:30 AM

Vergleichen Sie Laravel's Blade und die Twig-Vorlagen-Engine von CodeIgniter und wählen Sie je nach Projektanforderungen und persönlichen Vorlieben: Blade basiert auf der MVC-Syntax, die eine gute Codeorganisation und Vorlagenvererbung fördert. Twig ist eine Bibliothek eines Drittanbieters, die flexible Syntax, leistungsstarke Filter, erweiterten Support und eine Sicherheits-Sandbox bietet.

Laravel – Paginierungsanpassungen Laravel – Paginierungsanpassungen Aug 27, 2024 am 10:51 AM

Laravel – Paginierungsanpassungen – Laravel enthält eine Paginierungsfunktion, die einem Benutzer oder Entwickler hilft, eine Paginierungsfunktion einzubinden. Der Laravel-Paginator ist in den Abfrage-Builder und Eloquent ORM integriert. Die Paginierungsmethode automatisch

See all articles