Maison cadre php Laravel Comment utiliser Laravel pour implémenter la gestion des autorisations pour les applications de séparation front-end et back-end

Comment utiliser Laravel pour implémenter la gestion des autorisations pour les applications de séparation front-end et back-end

Apr 14, 2023 am 09:34 AM

Laravel est actuellement l'un des frameworks PHP les plus populaires, qui fournit un support puissant pour le développement d'applications Web. Le framework Laravel fournit également un très bon support pour le modèle de développement de séparation front-end et back-end, ce qui peut aider les développeurs à développer plus efficacement. Dans les applications avec séparation front-end et back-end, la gestion des autorisations est une partie très importante. Cet article présentera comment utiliser Laravel pour implémenter la gestion des autorisations des applications de séparation front-end et back-end.

1. Qu'est-ce qu'une application de séparation front-end et back-end ?

La séparation des applications front-end et back-end consiste à séparer la technologie utilisée par le front-end de la technologie utilisée par le back-end. Le front-end et le back-end ne forment plus un tout, mais communiquent via l'API. interfaces. Le front-end est généralement implémenté à l'aide de frameworks JavaScript, tandis que le back-end est implémenté à l'aide de langages tels que PHP et Java.

Dans une application séparée front-end et back-end, le front-end et le back-end sont chacun responsables de leur propre logique métier. Le front-end est responsable de la mise en œuvre de l'interface utilisateur et de l'interaction utilisateur, ainsi que de l'interface utilisateur. le back-end est responsable du traitement des données et de la mise en œuvre de la logique métier. Étant donné que les applications de séparation front-end et back-end séparent le front-end et le back-end, cela permet aux développeurs de se concentrer davantage sur leurs domaines d'expertise, améliorant ainsi l'efficacité du développement.

2. Pourquoi avez-vous besoin d'une gestion des autorisations ?

Dans les applications, le contrôle d'accès est un aspect très important. S’il n’existe pas de contrôle d’accès efficace, il est facile pour les attaquants d’exploiter les vulnérabilités pour effectuer des opérations illégales, telles que la modification de données, la suppression de données, etc. Par conséquent, il est très nécessaire d’ajouter la gestion des autorisations à l’application.

La gestion des autorisations fait référence à la gestion des autorisations de chaque rôle dans le système. Habituellement, certains rôles fixes sont définis, tels que les administrateurs, les utilisateurs ordinaires, etc., chaque rôle dispose d'autorisations fonctionnelles différentes. Les administrateurs ont la plus haute autorité et peuvent opérer sur toutes les données du système ; les utilisateurs ordinaires ne peuvent effectuer que certaines opérations de base.

Dans les applications de séparation front-end et back-end, la méthode de gestion des autorisations couramment utilisée est la gestion des autorisations par jeton. Le front-end doit transporter le jeton lors de l'envoi d'une demande, et le back-end vérifie le jeton pour déterminer si l'utilisateur dispose de droits d'accès. Par conséquent, chaque demande reçue du front-end nécessite une vérification du jeton.

3. Comment mettre en œuvre la gestion des autorisations pour les applications séparées front-end et back-end ?

Dans le framework Laravel, la gestion des autorisations est généralement implémentée via Laratrust. Laratrust est une bibliothèque de gestion des autorisations Laravel très facile à utiliser. Elle peut être utilisée pour implémenter très facilement la gestion des rôles et des autorisations.

Voici les étapes à suivre pour utiliser Laratrust pour implémenter la gestion des autorisations pour les applications séparées front-end et back-end :

  1. Installer Laratrust

Installer la bibliothèque Laratrust à l'aide de Composer dans un projet Laravel :

composer require santigarcor/laratrust
Copier après la connexion
  1. Exécuter la commande de publication Laratrust

Publier les fichiers de configuration Laratrust, les fichiers de migration, etc. :

php artisan vendor:publish --provider="Spatie\Permission\PermissionServiceProvider" --tag="laratrust"
Copier après la connexion
  1. Exécutez la commande de migration Laratrust

Exécutez la commande de migration Laratrust pour générer le rôle, l'autorisation, le rôle_utilisateur et d'autres tables :

php artisan migrate
Copier après la connexion
  1. Configurez Laratrust

dans le fichier config/auth.php, configurez guard comme API :

'guards' => [
    'web' => [
        'driver' => 'session',
        'provider' => 'users',
    ],

    'api' => [
        'driver' => 'token',
        'provider' => 'users',
    ],
],
Copier après la connexion

Dans le fichier config/laratrust.php, définissez les rôles et les autorisations :

'roles' => [
    'admin' => 'Admin',
    'user' => 'User',
],

'permissions' => [
    'create-post' => 'Create Post',
    'update-post' => 'Update Post',
    'delete-post' => 'Delete Post',
],
Copier après la connexion
  1. Create Token

Dans UserController, ajoutez un méthode de création de Token :

public function createToken(Request $request)
{
    $user = $request->user();
    $token = $user->createToken('api_token')->accessToken;
    return [$token];
}
Copier après la connexion
  1. Ajouter un middleware de Token

Dans le fichier app/Http/Kernel.php, ajoutez un middleware de Token :

protected $routeMiddleware = [
    // ...
    'token' => \App\Http\Middleware\TokenMiddleware::class,
];
Copier après la connexion

Dans le fichier app/Http/Middleware/TokenMiddleware.php, vérifiez le Token :

public function handle($request, Closure $next)
{
    $token = $request->header('Authorization');
    if (!$token) {
        return response(['message' => 'Token not provided'], 401);
    }
    $user = User::where('api_token', $token)->first();
    if (!$user) {
        return response(['message' => 'Invalid token'], 401);
    }
    return $next($request);
}
Copier après la connexion
  1. Utilisez le middleware Token dans le routage

Dans le routage, ajoutez le middleware Token :

Route::group(['middleware' => ['token', 'role:admin']], function () {
    Route::post('/posts', 'PostController@store');
    Route::put('/posts/{post}', 'PostController@update');
    Route::delete('/posts/{post}', 'PostController@destroy');
});
Copier après la connexion

Dans le code ci-dessus, chaque demande doit être vérifiée via le middleware Token, et il faut vérifier si elle dispose des autorisations du rôle d'administrateur .

4. Résumé

Cet article présente comment utiliser Laravel pour implémenter la gestion des autorisations pour les applications séparées front-end et back-end. La gestion des rôles et des autorisations peut être facilement mise en œuvre à l'aide de la bibliothèque Laratrust, et le middleware Token peut être utilisé pour vérifier chaque demande afin de garantir la sécurité de l'application.

Dans le développement actuel, la gestion des autorisations est un élément très nécessaire et doit être configurée de manière flexible en fonction des besoins réels. J'espère que cet article pourra aider les développeurs qui doivent mettre en œuvre la gestion des autorisations.

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!

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quel est le meilleur, Django ou Laravel? Quel est le meilleur, Django ou Laravel? Mar 28, 2025 am 10:41 AM

Django et Laravel sont tous deux des frameworks à pile. Django convient aux développeurs Python et à la logique métier complexe, tandis que Laravel convient aux développeurs PHP et à la syntaxe élégante. 1.Django est basé sur Python et suit la philosophie "Battery-Complete", adaptée au développement rapide et à une grande concurrence. 2.Laravel est basé sur PHP, mettant l'accent sur l'expérience du développeur et convient aux projets de petite et moyenne taille.

Laravel et le backend: alimentation logique d'application Web Laravel et le backend: alimentation logique d'application Web Apr 11, 2025 am 11:29 AM

Comment Laravel joue-t-il un rôle dans la logique backend? Il simplifie et améliore le développement backend par le biais de systèmes de routage, d'éloquente, d'authentification et d'autorisation, d'événements et d'auditeurs et d'optimisation des performances. 1. Le système de routage permet la définition de la structure d'URL et demande la logique de traitement. 2.Lao-éloquente simplifie l'interaction de la base de données. 3. Le système d'authentification et d'autorisation est pratique pour la gestion des utilisateurs. 4. L'événement et l'écoute implémentent la structure de code couplée de manière lâche. 5. L'optimisation des performances améliore l'efficacité de l'application par la mise en cache et la file d'attente.

Quel est le meilleur PHP ou Laravel? Quel est le meilleur PHP ou Laravel? Mar 27, 2025 pm 05:31 PM

PHP et Laravel ne sont pas directement comparables, car Laravel est un cadre basé sur PHP. 1.Php convient aux petits projets ou à un prototypage rapide car il est simple et direct. 2. Laravel convient à de grands projets ou à un développement efficace car il offre des fonctions et des outils riches, mais a une courbe d'apprentissage abrupte et peut ne pas être aussi bon que PHP pur.

Laravel est-il un frontend ou un backend? Laravel est-il un frontend ou un backend? Mar 27, 2025 pm 05:31 PM

LaravelisabackendFrameworkBuiltonPhp, conçue pourwebapplicationdevelopment.itfocusonServer-sidelogic, databasemanagement, andapplicationsstructure, andcanbenegrategratedwithfrontentechnologies likevue.jsorrectForfull-stackdevelopment.

Exemple d'introduction de Laravel Exemple d'introduction de Laravel Apr 18, 2025 pm 12:45 PM

Laravel est un cadre PHP pour la création facile des applications Web. Il fournit une gamme de fonctionnalités puissantes, notamment: Installation: Installez le Laravel CLI globalement avec Composer et créez des applications dans le répertoire du projet. Routage: définissez la relation entre l'URL et le gestionnaire dans Routes / web.php. Voir: Créez une vue dans les ressources / vues pour rendre l'interface de l'application. Intégration de la base de données: fournit une intégration prête à l'emploi avec des bases de données telles que MySQL et utilise la migration pour créer et modifier des tables. Modèle et contrôleur: le modèle représente l'entité de la base de données et le contrôleur traite les demandes HTTP.

Polyvylity de Laravel: des sites simples aux systèmes complexes Polyvylity de Laravel: des sites simples aux systèmes complexes Apr 13, 2025 am 12:13 AM

Le projet de développement de Laravel a été choisi en raison de sa flexibilité et de sa puissance pour répondre aux besoins de différentes tailles et complexités. Laravel fournit un système de routage, Eloquentorm, une ligne de commande artisanale et d'autres fonctions, soutenant le développement de blogs simples aux systèmes complexes au niveau de l'entreprise.

Comment apprendre Laravel comment apprendre Laravel gratuitement Comment apprendre Laravel comment apprendre Laravel gratuitement Apr 18, 2025 pm 12:51 PM

Vous voulez apprendre le cadre de Laravel, mais ne souffrez pas de ressources ni de pression économique? Cet article vous fournit un apprentissage gratuit de Laravel, vous apprenant à utiliser des ressources telles que les plateformes en ligne, les documents et les forums communautaires pour jeter une base solide pour votre parcours de développement PHP de la mise en place de maîtrise.

Pourquoi Laravel est-il si populaire? Pourquoi Laravel est-il si populaire? Apr 02, 2025 pm 02:16 PM

La popularité de Laravel comprend son processus de développement simplifié, offrant un environnement de développement agréable et des caractéristiques riches. 1) Il absorbe la philosophie de conception des rubyonrails, combinant la flexibilité de PHP. 2) Fournir des outils tels que l'éloquente, le moteur de modèle de lame, etc. pour améliorer l'efficacité du développement. 3) Son mécanisme d'architecture MVC et d'injection de dépendance rend le code plus modulaire et testable. 4) fournit des outils de débogage puissants et des méthodes d'optimisation des performances telles que les systèmes de mise en cache et les meilleures pratiques.

See all articles