Maison > cadre php > Laravel > Développement Laravel : Comment contrôler l'accès à l'aide de l'autorisation Laravel ?

Développement Laravel : Comment contrôler l'accès à l'aide de l'autorisation Laravel ?

王林
Libérer: 2023-06-13 23:22:12
original
1312 Les gens l'ont consulté

Développement Laravel : Comment utiliser l'autorisation Laravel pour contrôler l'accès ?

Laravel est un framework d'application Web PHP populaire qui fournit de nombreuses fonctionnalités et composants excellents qui peuvent nous aider à développer rapidement des applications Web de haute qualité. L'un d'eux est l'autorisation Laravel, qui est une fonctionnalité très utile de Laravel qui peut nous aider à contrôler l'accès à certaines opérations et pages sensibles dans les applications Web.

Qu'est-ce que l'autorisation Laravel ?

Laravel Authorization fait partie du framework Laravel, qui fournit un ensemble d'API et de fonctions qui peuvent nous aider à contrôler les autorisations des utilisateurs et le contrôle d'accès dans les applications Web. Grâce à l'autorisation Laravel, nous pouvons facilement définir et gérer les rôles et autorisations des utilisateurs pour protéger les données et les opérations sensibles dans les applications Web.

Comment utiliser l'autorisation Laravel ?

En utilisant l'autorisation Laravel, nous devons suivre les étapes suivantes :

  1. Définir les rôles et les autorisations des utilisateurs

Tout d'abord, nous devons définir les rôles et les autorisations des utilisateurs. Un rôle d'utilisateur est un ensemble de droits d'accès qui restreint l'accès d'un utilisateur à un contenu spécifique en fonction de son rôle. Par exemple, nous pouvons définir deux rôles : « Administrateur » et « Utilisateur ordinaire ». Les administrateurs peuvent accéder à toutes les pages et opérations, tandis que les utilisateurs ordinaires ne peuvent accéder qu'à certaines pages et opérations restreintes.

Dans Laravel, nous pouvons utiliser la politique d'autorisation de Laravel (Policy) pour définir les rôles et les autorisations des utilisateurs. La stratégie d'autorisation est une classe qui définit des règles d'autorisation. Elle contient un ensemble de règles qui autorisent ou refusent aux utilisateurs l'accès à certaines ressources. Nous pouvons définir une politique d'autorisation pour chaque modèle, puis l'utiliser dans le contrôleur pour vérifier les autorisations des utilisateurs.

Voici un exemple de politique d'autorisation simple pour empêcher l'utilisateur "admin" d'accéder à certaines ressources :

<?php

namespace AppPolicies;

use AppUser;
use IlluminateAuthAccessHandlesAuthorization;

class PostPolicy
{
    use HandlesAuthorization;

    public function before($user, $ability)
    {
        if ($user->role === 'admin') {
            return true;
        }
    }

    public function update(User $user, Post $post)
    {
        return $user->id === $post->user_id;
    }
}
Copier après la connexion

Dans l'exemple de code ci-dessus, nous avons défini une politique d'autorisation appelée PostPolicy. Dans la politique d'autorisation, nous définissons d'abord une méthode before. Dans cette méthode, nous déterminons si l'utilisateur actuel est un "administrateur". Si c'est le cas, nous retournerons directement true, sinon nous continuerons à exécuter d'autres règles de vérification.

Ensuite, nous définissons une méthode de mise à jour. Dans cette méthode, nous déterminons si l'utilisateur actuel est l'auteur de l'article. Si c'est le cas, renvoyons vrai, sinon renvoyons faux, indiquant que l'utilisateur actuel n'a pas l'autorisation de mettre à jour l'article. article.

  1. Utilisation de la politique d'autorisation dans le contrôleur

Après avoir défini la politique d'autorisation, nous devons l'utiliser dans le contrôleur. Utiliser la fonction d'autorisation dans Laravel est très simple, utilisez simplement la méthode d'autorisation dans le contrôleur. La méthode d'autorisation peut accepter deux paramètres. Le premier paramètre est le nom de la stratégie d'autorisation à utiliser et le deuxième paramètre est la ressource à vérifier.

Ce qui suit est un exemple de code de contrôleur pour vérifier si l'utilisateur a l'autorisation de mettre à jour l'article :

<?php

namespace AppHttpControllers;

use AppPost;
use IlluminateHttpRequest;

class PostController extends Controller
{
    public function update(Request $request, Post $post)
    {
        $this->authorize('update', $post);

        // 用户有权限更新文章,继续执行下面的代码...
    }
}
Copier après la connexion

Dans l'exemple ci-dessus, nous avons utilisé la méthode d'autorisation pour vérifier si l'utilisateur a l'autorisation de mettre à jour l'article. Si l'autorisation réussit, le code du contrôleur continuera à exécuter la logique suivante, sinon une exception sera levée.

  1. Utilisation des politiques d'autorisation dans les modèles Blade

En plus d'utiliser des politiques d'autorisation dans les contrôleurs, nous pouvons également utiliser des politiques d'autorisation dans les modèles Blade. L'utilisation des politiques d'autorisation dans les modèles est très simple, utilisez simplement les directives @can et @cannot.

Voici un exemple de code de modèle Blade pour afficher différents contenus en fonction du rôle de l'utilisateur :

@if (auth()->user()->can('update', $post))
    <a href="{{ route('posts.edit', $post) }}">编辑文章</a>
@endif
Copier après la connexion

Dans l'exemple ci-dessus, nous avons utilisé la directive @can pour afficher le lien "Modifier l'article" en fonction du rôle de l'utilisateur. Si l'utilisateur a l'autorisation de mettre à jour l'article, le lien sera affiché, sinon il ne sera pas affiché.

Résumé

L'autorisation Laravel est une fonctionnalité très utile du framework Laravel, qui peut nous aider à gérer facilement les rôles des utilisateurs et les droits d'accès, à protéger les données et les opérations sensibles dans les applications Web. Dans cet article, nous avons présenté comment utiliser l'autorisation Laravel pour contrôler les autorisations d'accès. Nous espérons que cet article vous sera utile.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal