Maison cadre php Laravel Comment utiliser Laravel pour implémenter la fonction de connexion tierce

Comment utiliser Laravel pour implémenter la fonction de connexion tierce

Nov 02, 2023 am 11:01 AM
laravel 功能 第三方登录

Comment utiliser Laravel pour implémenter la fonction de connexion tierce

Ces dernières années, avec le développement continu de la technologie Internet, les gens ont des exigences de plus en plus élevées en matière de sécurité et d'expérience utilisateur des sites Web ou des applications. Afin de faciliter l'enregistrement et la connexion des utilisateurs, la connexion à un compte tiers est devenue l'une des fonctions couramment utilisées dans les sites Web et les applications. En tant que framework PHP populaire, Laravel fournit une fonction d'autorisation de connexion sociale pratique, ce qui rend particulièrement pratique la mise en œuvre de fonctions de connexion tierces. Cet article expliquera comment utiliser Laravel pour implémenter la fonction de connexion tierce et fournira un code d'implémentation pour référence aux lecteurs.

1. Configurer les informations du fournisseur de services

Dans Laravel, nous pouvons utiliser le package d'autorisation de connexion sociale socialite pour implémenter la fonction de connexion tierce. socialite prend en charge une variété de fournisseurs de services autorisés, notamment Facebook, Google, Twitter, WeChat, etc. Par conséquent, avant d'utiliser socialite pour implémenter la fonction de connexion tierce, nous devons configurer les informations du fournisseur de services. socialite来实现第三方登录功能。而socialite支持的授权服务提供商多种多样,包括Facebook、Google、Twitter、WeChat等。因此,在使用socialite实现第三方登录功能之前,我们需要配置服务商信息。

以GitHub为例,通过创建并授权一个OAuth应用程序,我们可以获取到客户端ID和客户端密钥两个信息。具体的获取方式如下:

  1. 访问GitHub的网站,并登录账户。
  2. 进入GitHub的设置页面,选择"Developer settings"选项卡,点击"OAuth Apps",然后选择"New OAuth App"。
  3. 填写应用程序的详细信息,包括应用名称、应用主页URL、授权回调URL等。
  4. 提交并创建应用程序。创建成功后,可以在GitHub页面中找到该应用程序的客户端ID和客户端密钥等信息。

有了这些信息之后,我们就可以创建一个名为/config/services.php的Laravel配置文件,并在其中添加以下内容:

'github' => [
    'client_id' => env('GITHUB_CLIENT_ID'),
    'client_secret' => env('GITHUB_CLIENT_SECRET'),
    'redirect' => 'http://localhost:8000/login/github/callback',
],
Copier après la connexion

其中,github是我们要使用的服务提供商的名称,client_idclient_secret是我们在申请OAuth应用程序时获取到的客户端ID和客户端密钥,redirect是OAuth回调URL,它是我们在创建应用程序时填写的授权回调URL。这里我们设置为localhost:8000/login/github/callback,后面我们将会在路由文件中创建这个路由。

二、创建路由

接下来,我们需要在Laravel应用程序的路由文件中创建路由,实现通过GitHub登录的功能。在这里,我们可以使用Laravel的Route类来创建路由。

第一步,我们需要创建一个授权跳转路由,由它负责将用户跳转至GitHub登录页面。在路由文件中添加以下代码:

Route::get('login/github', function () {
    return Socialite::driver('github')->redirect();
});
Copier après la connexion

其中,Socialite::driver('github')调用socialite授权包的driver方法,获取到GitHub服务提供商的实例。而redirect方法则实现了OAuth授权跳转,将用户重定向到GitHub的认证授权页面上。

第二步,我们创建一个授权回调路由,由它负责获取GitHub服务提供商返回的用户信息,并进行处理。在路由文件中添加以下代码:

Route::get('login/github/callback', function () {
    $user = Socialite::driver('github')->user();
    // 处理用户信息
});
Copier après la connexion

其中,Socialite::driver('github')调用socialite授权包的driver方法,获取到GitHub服务提供商的实例。而user方法则实现了OAuth授权获取用户信息的过程,它会从GitHub服务提供商获取到用户的信息,该信息将以$user变量形式被返回。

在获取到$user变量之后,我们便可以对用户信息进行处理了。由于每个第三方服务提供商返回的用户信息格式略有不同,因此这里就不做详细展开了。

三、创建公用方法

为了方便管理和使用,我们可以在app/Http/Controllers/Auth/LoginController.php控制器中创建GitHub方法,供其他方法调用。

在该方法中,我们首先需要使用Socialite::driver('github')->redirect()方法将用户重定向到GitHub登录页面上。而在获取用户信息的回调过程中,我们可以在GitHubCallback方法中对用户信息进行处理。

下面是一个基本的示例代码:

<?php
namespace AppHttpControllersAuth;

use AppHttpControllersController;
use Socialite;

class LoginController extends Controller
{
    /**
     * 重定向到GitHub登录页面
     *
     * @return Response
     */
    public function GitHub()
    {
        return Socialite::driver('github')->redirect();
    }

    /**
     * 从GitHub获取用户信息
     *
     * @return Response
     */
    public function GitHubCallback()
    {
        $user = Socialite::driver('github')->user();
        dd($user);
    }
}
Copier après la connexion

四、使用扩展包

如果你觉得上述方法过程繁琐,可以使用社交化登录授权扩展包laravel/socialite,这个扩展包已经对各大服务提供商进行了封装,并提供了相对应的命令行工具来构造授权服务提供商。

  1. 安装laravel/socialite

在终端中使用composer安装laravel/socialite扩展包:

composer require laravel/socialite
Copier après la connexion
  1. 配置服务商信息

在Laravel的配置文件config/services.php中,添加需要使用的服务商信息,下面以GitHub为例:

'github' => [
    'client_id' => env('GITHUB_CLIENT_ID'),
    'client_secret' => env('GITHUB_CLIENT_SECRET'),
    'redirect' => '/auth/github/callback',
],
Copier après la connexion
  1. 创建授权路由

routes/web.php

En prenant GitHub comme exemple, en créant et autorisant une application OAuth, nous pouvons obtenir l'identifiant client et la clé client. La méthode spécifique pour l'obtenir est la suivante : 🎜
  1. Visitez le site Web de GitHub et connectez-vous à votre compte.
  2. Accédez à la page des paramètres de GitHub, sélectionnez l'onglet « Paramètres du développeur », cliquez sur « Applications OAuth », puis sélectionnez « Nouvelle application OAuth ».
  3. Remplissez les informations détaillées de l'application, notamment le nom de l'application, l'URL de la page d'accueil de l'application, l'URL de rappel d'autorisation, etc.
  4. Soumettez et créez la candidature. Après une création réussie, des informations telles que l'ID client et la clé client de l'application peuvent être trouvées sur la page GitHub.
🎜Avec ces informations, nous pouvons créer un fichier de configuration Laravel nommé /config/services.php et y ajouter le contenu suivant : 🎜
Route::get('/auth/github', 'AuthLoginController@GitHub');
Copier après la connexion
Copier après la connexion
🎜 Parmi eux, github est le nom du fournisseur de services que nous souhaitons utiliser, client_id et client_secret sont les clients que nous avons obtenus lors de la candidature à l'application OAuth. L'ID client et secret client, redirect est l'URL de rappel OAuth, qui est l'URL de rappel d'autorisation que nous avons renseignée lors de la création de l'application. Ici, nous le définissons sur localhost:8000/login/github/callback Nous créerons cette route dans le fichier de routage plus tard. 🎜🎜2. Créer une route🎜🎜Ensuite, nous devons créer une route dans le fichier de routage de l'application Laravel pour implémenter la fonction de connexion via GitHub. Ici, nous pouvons utiliser la classe Route de Laravel pour créer des itinéraires. 🎜🎜La première étape consiste à créer une route de redirection d'autorisation, chargée de rediriger les utilisateurs vers la page de connexion GitHub. Ajoutez le code suivant dans le fichier de routage : 🎜
Route::get('/auth/github/callback', 'AuthLoginController@GitHubCallback');
Copier après la connexion
Copier après la connexion
🎜 Parmi eux, Socialite::driver('github') appelle la méthode driver du socialite</ code> package d'autorisation , obtenez l'instance du fournisseur de services GitHub. La méthode <code>redirect implémente le saut d'autorisation OAuth et redirige l'utilisateur vers la page d'authentification et d'autorisation de GitHub. 🎜🎜Dans la deuxième étape, nous créons une route de rappel d'autorisation, qui est chargée d'obtenir les informations utilisateur renvoyées par le fournisseur de services GitHub et de les traiter. Ajoutez le code suivant dans le fichier de routage : 🎜
use Socialite;

class LoginController extends Controller
{

    public function GitHub()
    {
        return Socialite::driver('github')->redirect();
    }

    public function GitHubCallback()
    {
        $user = Socialite::driver('github')->user();
        dd($user);
    }

}
Copier après la connexion
Copier après la connexion
🎜 Parmi eux, Socialite::driver('github') appelle la méthode driver du socialite</ code> package d'autorisation , obtenez l'instance du fournisseur de services GitHub. La méthode <code>user implémente le processus d'obtention des informations utilisateur via l'autorisation OAuth. Elle obtiendra les informations de l'utilisateur auprès du fournisseur de services GitHub, qui seront stockées sous la forme du $user</code. > retour variable. 🎜🎜Après avoir obtenu la variable <code>$user, nous pouvons traiter les informations utilisateur. Le format des informations utilisateur renvoyées par chaque fournisseur de services tiers étant légèrement différent, nous n’entrerons pas dans les détails ici. 🎜🎜3. Créer des méthodes publiques🎜🎜Afin de faciliter la gestion et l'utilisation, nous pouvons créer une méthode GitHub dans le fichier app/Http/Controllers/Auth/LoginController.php. contrôleur. pour d’autres méthodes à appeler. 🎜🎜Dans cette méthode, nous devons d'abord utiliser la méthode Socialite::driver('github')->redirect() pour rediriger l'utilisateur vers la page de connexion GitHub. Pendant le processus de rappel d'obtention des informations utilisateur, nous pouvons traiter les informations utilisateur dans la méthode GitHubCallback. 🎜🎜Ce qui suit est un exemple de code de base : 🎜rrreee🎜4. Utilisez le package d'extension 🎜🎜Si vous pensez que la méthode ci-dessus est lourde, vous pouvez utiliser le package d'extension d'autorisation de connexion sociale laravel/socialite. , ce package d'extension Les principaux fournisseurs de services ont été encapsulés et les outils de ligne de commande correspondants ont été fournis pour construire des fournisseurs de services autorisés. 🎜
  1. Installez laravel/socialite
🎜Utilisez composer dans le terminal pour installer le package d'extension laravel/socialite : 🎜rrreee
  1. Configurer les informations du fournisseur de services
🎜Dans le fichier de configuration de Laravel config/services.php, ajoutez les informations du fournisseur de services que vous devez utiliser , comme suit Prenons GitHub comme exemple : 🎜rrreee
  1. Créer une route d'autorisation
🎜Dans le fichier de routage routes/web.php , créez une route d'autorisation vérifiée : 🎜
Route::get('/auth/github', 'AuthLoginController@GitHub');
Copier après la connexion
Copier après la connexion
  1. 创建回调路由

routes/web.php路由文件中,创建一个授权回调路由:

Route::get('/auth/github/callback', 'AuthLoginController@GitHubCallback');
Copier après la connexion
Copier après la connexion
  1. 创建控制器

app/Http/Controllers/Auth目录下,创建一个名为LoginController.php的控制器。控制器中添加方法GitHubGitHubCallback实现授权和回调过程,具体代码如下:

use Socialite;

class LoginController extends Controller
{

    public function GitHub()
    {
        return Socialite::driver('github')->redirect();
    }

    public function GitHubCallback()
    {
        $user = Socialite::driver('github')->user();
        dd($user);
    }

}
Copier après la connexion
Copier après la connexion

至此,我们已经成功使用laravel/socialite扩展包实现了第三方登录的功能。

总结:

本文介绍了如何使用Laravel框架的社交化登录授权包socialite,在实现第三方登录功能方面变得尤为便利。通过配置服务商信息、创建路由以及使用扩展包等方法,我们可以轻松地实现通过GitHub登录的功能。希望这篇文章能够对各位开发人员有所帮助。

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)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois 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)

Comparaison des dernières versions de Laravel et CodeIgniter Comparaison des dernières versions de Laravel et CodeIgniter Jun 05, 2024 pm 05:29 PM

Les dernières versions de Laravel 9 et CodeIgniter 4 fournissent des fonctionnalités et des améliorations mises à jour. Laravel9 adopte l'architecture MVC et fournit des fonctions telles que la migration de bases de données, l'authentification et le moteur de modèles. CodeIgniter4 utilise l'architecture HMVC pour fournir le routage, l'ORM et la mise en cache. En termes de performances, le modèle de conception basé sur le fournisseur de services de Laravel9 et le framework léger de CodeIgniter4 lui confèrent d'excellentes performances. Dans les applications pratiques, Laravel9 convient aux projets complexes qui nécessitent de la flexibilité et des fonctions puissantes, tandis que CodeIgniter4 convient au développement rapide et aux petites applications.

Comment les capacités de traitement des données de Laravel et de CodeIgniter se comparent-elles ? Comment les capacités de traitement des données de Laravel et de CodeIgniter se comparent-elles ? Jun 01, 2024 pm 01:34 PM

Comparez les capacités de traitement des données de Laravel et CodeIgniter : ORM : Laravel utilise EloquentORM, qui fournit un mappage relationnel classe-objet, tandis que CodeIgniter utilise ActiveRecord pour représenter le modèle de base de données en tant que sous-classe de classes PHP. Générateur de requêtes : Laravel dispose d'une API de requêtes chaînées flexible, tandis que le générateur de requêtes de CodeIgniter est plus simple et basé sur des tableaux. Validation des données : Laravel fournit une classe Validator qui prend en charge les règles de validation personnalisées, tandis que CodeIgniter a moins de fonctions de validation intégrées et nécessite un codage manuel des règles personnalisées. Cas pratique : l'exemple d'enregistrement d'utilisateur montre Lar

Laravel - Commandes artisanales Laravel - Commandes artisanales Aug 27, 2024 am 10:51 AM

Laravel - Artisan Commands - Laravel 5.7 est livré avec une nouvelle façon de traiter et de tester de nouvelles commandes. Il inclut une nouvelle fonctionnalité de test des commandes artisanales et la démonstration est mentionnée ci-dessous ?

Quelle est la devise GateToken(GT) ? Introduction aux fonctions des pièces GT et à l'économie des jetons Quelle est la devise GateToken(GT) ? Introduction aux fonctions des pièces GT et à l'économie des jetons Jul 15, 2024 pm 04:36 PM

Quelle est la devise GateToken(GT) ? GT (GateToken) est l'actif natif de la chaîne GateChain et la devise officielle de la plateforme Gate.io. La valeur des pièces GT est étroitement liée au développement de l’écologie Gate.io et GateChain. Qu’est-ce que GateChain ? GateChain est née en 2018 et est une nouvelle génération de chaîne publique performante lancée par Gate.io. GateChain se concentre sur la protection de la sécurité des actifs en chaîne des utilisateurs et sur la fourniture de services de transaction décentralisés pratiques. L'objectif de GateChain est de créer un écosystème de stockage, de distribution et de transaction d'actifs numériques décentralisé, sécurisé et efficace au niveau de l'entreprise. Gatechain a l'original

Lequel est le plus adapté aux débutants, Laravel ou CodeIgniter ? Lequel est le plus adapté aux débutants, Laravel ou CodeIgniter ? Jun 05, 2024 pm 07:50 PM

Pour les débutants, CodeIgniter a une courbe d'apprentissage plus douce et moins de fonctionnalités, mais couvre les besoins de base. Laravel offre un ensemble de fonctionnalités plus large mais a une courbe d'apprentissage légèrement plus raide. En termes de performances, Laravel et CodeIgniter fonctionnent bien. Laravel dispose d'une documentation plus complète et d'un support communautaire actif, tandis que CodeIgniter est plus simple, léger et possède de solides fonctionnalités de sécurité. Dans le cas pratique de la création d'une application de blog, EloquentORM de Laravel simplifie la manipulation des données, tandis que CodeIgniter nécessite une configuration plus manuelle.

Laravel vs CodeIgniter : quel framework est le meilleur pour les grands projets ? Laravel vs CodeIgniter : quel framework est le meilleur pour les grands projets ? Jun 04, 2024 am 09:09 AM

Lors du choix d'un framework pour de grands projets, Laravel et CodeIgniter ont chacun leurs propres avantages. Laravel est conçu pour les applications d'entreprise, offrant une conception modulaire, une injection de dépendances et un ensemble de fonctionnalités puissantes. CodeIgniter est un framework léger plus adapté aux projets de petite et moyenne taille, mettant l'accent sur la rapidité et la facilité d'utilisation. Pour les grands projets avec des exigences complexes et un grand nombre d'utilisateurs, la puissance et l'évolutivité de Laravel sont plus adaptées. Pour les projets simples ou les situations avec des ressources limitées, les capacités de développement légères et rapides de CodeIgniter sont plus idéales.

Laravel vs CodeIgniter : quel framework est le meilleur pour les petits projets ? Laravel vs CodeIgniter : quel framework est le meilleur pour les petits projets ? Jun 04, 2024 pm 05:29 PM

Pour les petits projets, Laravel convient aux projets plus importants qui nécessitent des fonctionnalités et une sécurité élevées. CodeIgniter convient aux très petits projets qui nécessitent légèreté et facilité d'utilisation.

Quel est le meilleur moteur de template, Laravel ou CodeIgniter ? Quel est le meilleur moteur de template, Laravel ou CodeIgniter ? Jun 03, 2024 am 11:30 AM

En comparant le moteur de modèles Blade de Laravel et le moteur de modèles Twig de CodeIgniter, choisissez en fonction des besoins du projet et de vos préférences personnelles : Blade est basé sur la syntaxe MVC, qui encourage une bonne organisation du code et un héritage de modèles. Twig est une bibliothèque tierce qui offre une syntaxe flexible, des filtres puissants, une prise en charge étendue et un bac à sable de sécurité.

See all articles