Heim > Web-Frontend > js-Tutorial > Beispiel für die Vervollständigung der Benutzerautorisierung mithilfe einer Richtlinie in Laravel

Beispiel für die Vervollständigung der Benutzerautorisierung mithilfe einer Richtlinie in Laravel

小云云
Freigeben: 2018-03-13 14:47:46
Original
2382 Leute haben es durchsucht

Laravel bietet eine einfachere Möglichkeit, Benutzerautorisierungsaktionen durchzuführen. Ähnlich wie bei der Benutzerauthentifizierung verfügt Laravel über zwei Hauptmethoden zur Implementierung der Benutzerautorisierung: Gates und Richtlinien. Zeichnen Sie hier die Verwendung von Richtlinien auf. Die Verwendung von Richtlinien zum Vervollständigen der Benutzerautorisierung umfasst hauptsächlich drei Schritte:

Richtlinienklasse definieren
Richtlinienklasse und Modellzuordnung registrieren
Richtlinienbeurteilung

Richtlinienklasse definieren

Strategie ist eine Klasse, die die Autorisierungslogik in einem bestimmten Modell oder einer bestimmten Ressource organisiert. Wenn es sich bei der Anwendung beispielsweise um einen Blog handelt, gibt es ein Post-Modell und eine entsprechende PostPolicy, um Benutzeraktionen zu autorisieren, z. B. das Erstellen oder Aktualisieren eines Blogs oder das Löschen eines Blogs.

An dieser Stelle können Sie den Befehl artisan verwenden, um eine Richtlinienklasse zu erstellen. Der folgende Befehl erstellt eine leere Post-Richtlinienklasse

php artisan make:policy PostPolicy
Nach dem Login kopieren
Nach dem Login kopieren

Die generierte Richtlinie wird in der App/den Richtlinien platziert Verzeichnis. Wenn dieses Verzeichnis in Ihrer Anwendung nicht vorhanden ist, erstellt Laravel es automatisch.

Wenn Sie eine Strategieklasse mit CURD generieren möchten, können Sie sich mit dem folgenden Handwerkerbefehl

php artisan make:policy PostPolicy --model=Post
Nach dem Login kopieren
Nach dem Login kopieren

registrieren die dem Modell zugeordnete Strategieklasse

Registrieren Sie die Richtlinienklasse im AuthServiceProvider

    protected $policies = [        //'App\Model' => 'App\Policies\ModelPolicy',  这个是laravel中默认注册了的policy,可以模仿这个注册我们自己的policy        'App\Post' => 'App\Policies\PostPolicy', //注册Post的policy
    ];
Nach dem Login kopieren
Nach dem Login kopieren

Das Zuordnen der Richtlinienklasse zum Modell bedeutet, dass wir unsere Richtlinienmethode in die Richtlinie schreiben

<?phpnamespace App\Policies;use App\User;use App\Post;use Illuminate\Auth\Access\HandlesAuthorization;class PostPolicy{
    use HandlesAuthorization;    /**
     * Determine whether the user can update the post.
     *
     * @param  \App\User  $user
     * @param  \App\Post  $post
     * @return mixed
     */
    public function update(User $user, Post $post)
    {
        //
        return $user->id === $post->user_id;
    }    /**
     * Determine whether the user can delete the post.
     *
     * @param  \App\User  $user
     * @param  \App\Post  $post
     * @return mixed
     */
    public function delete(User $user, Post $post)
    {
        //
        return $user->id === $post->user_id;
    }
Nach dem Login kopieren
Nach dem Login kopieren

Update-Methode Akzeptiert Benutzer- und Beitragsinstanzen als Parameter und sollte „true“ oder „false“ zurückgeben, um anzugeben, ob der Benutzer berechtigt ist, den angegebenen Beitrag zu aktualisieren. Daher ermitteln wir in diesem Beispiel, ob die Benutzer-ID mit der Benutzer-ID im Beitrag übereinstimmt,

Richtlinienbeurteilung

Hier verwenden wir die Controller-Hilfsfunktion im Controller, um eine Richtlinienbeurteilung vorzunehmen

//文章编辑逻辑
    public function update(Post $post)
    {
        $this->validate(request(),[            &#39;title&#39;      => &#39;required|String|min:5|max:50&#39;,            &#39;content&#39;    => &#39;required|String|min:10&#39;,
        ]);
        $this->authorize(&#39;update&#39;,$post);         ////////////////////策略判断
        $post->title = request(&#39;title&#39;);
        $post->content = request(&#39;content&#39;);
        $post->save();        return redirect("/posts/{$post->id}");
    }    //文章删除
    public function delete(Post $post)
    {        //TODO::权限验证
        $this->authorize(&#39;delete&#39;,$post);           //////////////////策略判断
        $post->delete();        return redirect(&#39;/posts&#39;);
    }
Nach dem Login kopieren
Nach dem Login kopieren

Solange die Überprüfung fehlschlägt, löst Laravel automatisch eine HttpException aus. Diese Aktion ist nicht autorisiert.

Während der Entwicklung müssen wir möglicherweise basierend auf den Berechtigungen des Benutzers bestimmen, ob einige Schaltflächen angezeigt werden sollen, z Wie in der Ansichtsschaltfläche „Bearbeiten“ oder „Ändern“ können wir in Blade mit @can angeben, ob die Schaltfläche „Modell“ angezeigt wird.

Laravel bietet eine einfachere Möglichkeit, die Benutzerautorisierung zu handhaben Aktionen. Ähnlich wie bei der Benutzerauthentifizierung verfügt Laravel über zwei Hauptmethoden zur Implementierung der Benutzerautorisierung: Gates und Richtlinien.

Erfassen Sie hier die Verwendung von Richtlinien. Die Verwendung von Richtlinien zur Vervollständigung der Benutzerautorisierung umfasst hauptsächlich drei Schritte:

Richtlinienklasse definieren
Richtlinienklasse und Modellzuordnung registrieren
Richtlinienbeurteilung

Richtlinienklassen definieren

Eine Richtlinie ist eine Klasse, die die Autorisierungslogik in einem bestimmten Modell oder einer bestimmten Ressource organisiert. Wenn es sich bei der Anwendung beispielsweise um einen Blog handelt, gibt es ein Post-Modell und eine entsprechende PostPolicy, um Benutzeraktionen wie das Erstellen oder Aktualisieren eines Blogs oder das Löschen eines Blogs zu autorisieren.

An dieser Stelle können Sie den Befehl artisan verwenden, um eine Richtlinienklasse zu erstellen. Der folgende Befehl erstellt eine leere Post-Richtlinienklasse

php artisan make:policy PostPolicy
Nach dem Login kopieren
Nach dem Login kopieren

Die generierte Richtlinie wird in der App/den Richtlinien platziert Verzeichnis. Wenn dieses Verzeichnis in Ihrer Anwendung nicht vorhanden ist, erstellt Laravel es automatisch

Wenn Sie eine Strategieklasse mit CURD generieren möchten, können Sie sich mit dem folgenden Handwerkerbefehl

php artisan make:policy PostPolicy --model=Post
Nach dem Login kopieren
Nach dem Login kopieren

registrieren die dem Modell zugeordnete Strategieklasse

Registrieren Sie die Richtlinienklasse im AuthServiceProvider

    protected $policies = [        //&#39;App\Model&#39; => &#39;App\Policies\ModelPolicy&#39;,  这个是laravel中默认注册了的policy,可以模仿这个注册我们自己的policy        &#39;App\Post&#39; => &#39;App\Policies\PostPolicy&#39;, //注册Post的policy
    ];
Nach dem Login kopieren
Nach dem Login kopieren

Das Zuordnen der Richtlinienklasse zum Modell bedeutet, dass wir unsere Richtlinienmethode in die Richtlinie schreiben

<?phpnamespace App\Policies;use App\User;use App\Post;use Illuminate\Auth\Access\HandlesAuthorization;class PostPolicy{
    use HandlesAuthorization;    /**
     * Determine whether the user can update the post.
     *
     * @param  \App\User  $user
     * @param  \App\Post  $post
     * @return mixed
     */
    public function update(User $user, Post $post)
    {
        //
        return $user->id === $post->user_id;
    }    /**
     * Determine whether the user can delete the post.
     *
     * @param  \App\User  $user
     * @param  \App\Post  $post
     * @return mixed
     */
    public function delete(User $user, Post $post)
    {
        //
        return $user->id === $post->user_id;
    }
Nach dem Login kopieren
Nach dem Login kopieren

Update-Methode Akzeptiert Benutzer- und Beitragsinstanzen als Parameter und sollte „true“ oder „false“ zurückgeben, um anzugeben, ob der Benutzer berechtigt ist, den angegebenen Beitrag zu aktualisieren. Daher ermitteln wir in diesem Beispiel, ob die Benutzer-ID mit der Benutzer-ID im Beitrag übereinstimmt,

Richtlinienbeurteilung

Hier verwenden wir die Controller-Hilfsfunktion im Controller, um eine Richtlinienbeurteilung vorzunehmen

//文章编辑逻辑
    public function update(Post $post)
    {
        $this->validate(request(),[            &#39;title&#39;      => &#39;required|String|min:5|max:50&#39;,            &#39;content&#39;    => &#39;required|String|min:10&#39;,
        ]);
        $this->authorize(&#39;update&#39;,$post);         ////////////////////策略判断
        $post->title = request(&#39;title&#39;);
        $post->content = request(&#39;content&#39;);
        $post->save();        return redirect("/posts/{$post->id}");
    }    //文章删除
    public function delete(Post $post)
    {        //TODO::权限验证
        $this->authorize(&#39;delete&#39;,$post);           //////////////////策略判断
        $post->delete();        return redirect(&#39;/posts&#39;);
    }
Nach dem Login kopieren
Nach dem Login kopieren

Solange die Überprüfung fehlschlägt, löst Laravel automatisch eine HttpException aus. Diese Aktion ist nicht autorisiert.

Während der Entwicklung müssen wir möglicherweise basierend auf den Berechtigungen des Benutzers bestimmen, ob einige Schaltflächen angezeigt werden sollen, z Wie in der Ansichtsschaltfläche „Bearbeiten“ oder „Ändern“ können wir in Blade mit @can angeben, ob die Modellschaltfläche angezeigt wird.

Das obige ist der detaillierte Inhalt vonBeispiel für die Vervollständigung der Benutzerautorisierung mithilfe einer Richtlinie in Laravel. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage