Maison cadre php Laravel Explication détaillée du processus d'authentification de Possport Api dans le framework Laravel (image et texte)

Explication détaillée du processus d'authentification de Possport Api dans le framework Laravel (image et texte)

Aug 04, 2018 pm 03:00 PM

Le contenu de cet article est de partager avec vous une explication détaillée (images et texte) du processus de certification de l'API Possport dans le framework Laravel. Le contenu est très détaillé et a une certaine valeur de référence. amis dans le besoin.

1. Laravel a rendu l'authentification des utilisateurs très simple via le formulaire de connexion traditionnel, mais qu'en est-il de l'API ? Les API utilisent généralement des jetons pour l'authentification et ne maintiennent pas l'état de session entre les requêtes. Laravel utilise Laravel Passport pour faciliter l'authentification API. Passport est basé sur le serveur League OAuth2 maintenu par Alex Bilbie et peut fournir une implémentation complète du serveur OAuth2 pour les applications Laravel en quelques minutes.

2. Installez

composer require laravel/passport
Copier après la connexion

3. Ensuite, enregistrez le config/app.php fournisseur de services dans le tableau providers du fichier de configuration Passport :

 Laravel\Passport\PassportServiceProvider::class,
Copier après la connexion

4.La migration du passeport générera une table de données pour que l'application stocke les clients et les jetons d'accès (emplacement du fichier de migration/fournisseur/laravel/passport/base de données) (créer des tables associées)

 php artisan migrate
Copier après la connexion

5. clés de cryptage et clients d'accès privé et d'accès par mot de passe utilisés pour générer des jetons d'accès sécurisés.

 php artisan passport:install
Copier après la connexion

Remarque : il y aura un problème ici, c'est-à-dire que lorsque vous vous inscrirez et utiliserez à nouveau l'interface d'enregistrement du proxy, une erreur sera signalée à nouveau php artisan passport:install et tout ira bien <. 🎜>

6.

est ajouté au modèle Trait Ce trait fournira à ce modèle quelques fonctions auxiliaires pour vérifier le jeton de l'utilisateur authentifié et l'utiliser. AppUser

Laravel\Passport\HasApiTokens
Copier après la connexion

Explication détaillée du processus dauthentification de Possport Api dans le framework Laravel (image et texte)

7. Ajoutez ensuite

AuthServiceProviderbootPassport::roues();8. Enfin, modifiez le fichier L'élément de protection d'autorisation (
) dans la partie Explication détaillée du processus dauthentification de Possport Api dans le framework Laravel (image et texte) de
est remplacé par config/auth.php. Cet ajustement permettra à votre application d'utiliser TokenGuard de Passport pour gérer lors de la réception d'une demande d'autorisation APIapidriverpassport9 Ajouter un routage de test api.php
Explication détaillée du processus dauthentification de Possport Api dans le framework Laravel (image et texte)
10. >

php artisan make:controller ApiUserController
Route::group([&#39;namespace&#39;=>&#39;api&#39;], function(){    
        // 无需认证路由    
        Route::match([&#39;get&#39;,&#39;post&#39;],&#39;/login&#39;, &#39;UserController@login&#39;)->name(&#39;login&#39;);
        Route::post(&#39;/register&#39;, &#39;UserController@register&#39;);
        // 需认证路由    
        Route::group([&#39;middleware&#39; => &#39;auth:api&#39;], function(){
        Route::get(&#39;/v1/passport&#39;, &#39;UserController@passport&#39;);
    });
    });
Copier après la connexion

11. Effectuez un test simple via postman pour obtenir le jeton

Enregistrement :

Adresse de l'interface : http://gems. /register
<?php
namespace App\Http\Controllers\Api;
use App\User;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Validator;
class UserController extends Controller{
    public function __construct(){
        $this->content = array();
    }    
    public function login(){
        //dd(request(&#39;name&#39;));
        if(Auth::attempt([&#39;name&#39; => request(&#39;name&#39;), &#39;password&#39; => request(&#39;password&#39;)])) {            
        $user = Auth::user();            
        $this->content[&#39;token&#39;] =  $user->createToken(request(&#39;name&#39;))->accessToken;            
        $status = 200;
        } else {            
        $this->content[&#39;error&#39;] = "未授权";            
        $status = 401;
        }        
        return response()->json($this->content, $status);
    }    public function passport(){
        return response()->json([&#39;user&#39; => Auth::user()]);
    }    /**
     * 注册用户创建token
     */
    public function register(Request $request){
        $input = $request->all();        
        $validator = Validator::make($input, [
                    &#39;email&#39; => &#39;required|string|email|max:255|unique:users|min:4&#39;,            
                    &#39;password&#39; => &#39;required|string|min:6&#39;,
        ]);        
        if ($validator->fails())
         {            
            return response()->json([&#39;error&#39;=>$validator->errors()], 401);
        }        
        $input[&#39;password&#39;] = bcrypt($input[&#39;password&#39;]);        
        $user = User::create($input);        
        if( $user !==false){            
        $success[&#39;token&#39;] =  $user->createToken($input[&#39;name&#39;])->accessToken;            
        $success[&#39;email&#39;] =  $user->email;            
        $success[&#39;uid&#39;] =  $user->id;            
        return response()->json([&#39;error_code&#39;=>0,&#39;data&#39;=>$success], 200);
        }        
        return response()->json([&#39;error_code&#39;=>1,&#39;data&#39;=>$input], 401);
    }
}
Copier après la connexion


Connexion : http://gems.com/api/login

Explication détaillée du processus dauthentification de Possport Api dans le framework Laravel (image et texte)
Test pour obtenir des informations sur l'utilisateur : http://gems com/. api/v1/passport
Explication détaillée du processus dauthentification de Possport Api dans le framework Laravel (image et texte)

Articles connexes recommandés :
Explication détaillée du processus dauthentification de Possport Api dans le framework Laravel (image et texte)

Comment créer et utiliser le modèle de modèle de framework Laravel

Comment partager des données entre vues dans le framework laravel5.5 ? Deux méthodes de partage de données entre vues (avec code)

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

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)

Comment construire une API RESTful avec des fonctionnalités avancées à Laravel? Comment construire une API RESTful avec des fonctionnalités avancées à Laravel? Mar 11, 2025 pm 04:13 PM

Cet article guide la construction d'API Robust Laravel Restful. Il couvre la configuration du projet, la gestion des ressources, les interactions de base de données, la sérialisation, l'authentification, l'autorisation, les tests et les meilleures pratiques de sécurité cruciale. Aborder l'évolutivité chall

Comment mettre en œuvre l'authentification et l'autorisation OAuth2 dans Laravel? Comment mettre en œuvre l'authentification et l'autorisation OAuth2 dans Laravel? Mar 12, 2025 pm 05:56 PM

Cet article détaille la mise en œuvre d'authentification et d'autorisation OAuth 2.0 dans Laravel. Il couvre à l'aide de packages comme les solutions de ligue / oauth2-serveur ou spécifiques au fournisseur, mettant l'accent sur la configuration de la base de données, l'enregistrement du client, la configuration du serveur d'autorisation

Comment utiliser les composants de Laravel pour créer des éléments d'interface utilisateur réutilisables? Comment utiliser les composants de Laravel pour créer des éléments d'interface utilisateur réutilisables? Mar 17, 2025 pm 02:47 PM

L'article discute de la création et de la personnalisation des éléments d'interface utilisateur réutilisables dans Laravel à l'aide de composants, offrant les meilleures pratiques pour l'organisation et suggérant des packages améliorant.

Comment créer et utiliser des directives de lame personnalisées à Laravel? Comment créer et utiliser des directives de lame personnalisées à Laravel? Mar 17, 2025 pm 02:50 PM

L'article discute de la création et de l'utilisation des directives de lame personnalisées à Laravel pour améliorer les modèles. Il couvre la définition des directives, les utilisant dans des modèles et les gérer dans de grands projets, mettant en évidence des avantages tels que l'amélioration de la réutilisabilité du code et R

Quelles sont les meilleures pratiques pour utiliser Laravel dans un environnement natif du cloud? Quelles sont les meilleures pratiques pour utiliser Laravel dans un environnement natif du cloud? Mar 14, 2025 pm 01:44 PM

L'article traite des meilleures pratiques pour déployer Laravel dans des environnements natifs du cloud, en se concentrant sur l'évolutivité, la fiabilité et la sécurité. Les problèmes clés incluent la conteneurisation, les microservices, la conception sans état et les stratégies d'optimisation.

Comment puis-je créer et utiliser des règles de validation personnalisées dans Laravel? Comment puis-je créer et utiliser des règles de validation personnalisées dans Laravel? Mar 17, 2025 pm 02:38 PM

L'article discute de la création et de l'utilisation de règles de validation personnalisées dans Laravel, offrant des étapes pour les définir et les mettre en œuvre. Il met en évidence des avantages tels que la réutilisabilité et la spécificité et fournit des méthodes pour étendre le système de validation de Laravel.

Quelles sont les meilleures façons de gérer les téléchargements de fichiers et le stockage cloud dans Laravel? Quelles sont les meilleures façons de gérer les téléchargements de fichiers et le stockage cloud dans Laravel? Mar 12, 2025 pm 05:54 PM

Cet article explore des stratégies optimales de téléchargement de fichiers et de stockage cloud dans Laravel. Il examine le stockage local vs fournisseurs de cloud (AWS S3, Google Cloud, Azure, DigitalOcean), mettant l'accent sur la sécurité (validation, désinfection, HTTPS) et Performance Opti

Comment utiliser la console artisanale de Laravel pour automatiser les tâches courantes? Comment utiliser la console artisanale de Laravel pour automatiser les tâches courantes? Mar 17, 2025 pm 02:39 PM

La console artisanale de Laravel automatise des tâches comme la génération de code, l'exécution de migrations et la planification. Les commandes clés incluent la marque: contrôleur, migrer et db: graines. Les commandes personnalisées peuvent être créées pour des besoins spécifiques, améliorant l'efficacité du flux de travail.

See all articles