


Développement Laravel : Comment implémenter la connexion sociale à l'aide de Laravel Socialite ?
À l’ère actuelle des réseaux sociaux, qui se développent de plus en plus, la connexion sociale est devenue une fonctionnalité standard sur de plus en plus de sites Web. Cela permet non seulement aux utilisateurs de se connecter rapidement, mais aide également le site Web à augmenter le trafic des utilisateurs et les interactions sociales. Bien qu'il ne soit pas difficile de mettre en œuvre vous-même la connexion sociale, l'utilisation de composants de connexion sociale prêts à l'emploi peut permettre d'économiser du temps et des efforts. Dans le développement PHP, Laravel Socialite est un composant de connexion sociale facile à utiliser. Voyons comment l'utiliser pour implémenter la connexion sociale.
1. Installez Laravel Socialite
Nous devons d'abord installer le package Socialite dans l'application Laravel, utilisez la commande suivante :
composer require laravel /socialite
composer require laravel/socialite
安装完成之后,在 config/app.php
文件中添加 Socialite 服务提供器:
'providers' => [ // Other service providers... LaravelSocialiteSocialiteServiceProvider::class, ]
然后在 config/app.php
文件中添加 Socialite 门面别名:
'aliases' => [ // Other aliases... 'Socialite' => LaravelSocialiteFacadesSocialite::class, ]
这样我们就成功安装了 Socialite 组件。
二、创建社交登录应用
Socialite 可以支持许多不同的社交登录应用,我们需要为每个应用创建一个应用程序。下面以 GitHub 为例演示在 GitHub 上创建一个新的 OAuth 应用。
- 首先,登录你的 GitHub 账户,在头像下拉菜单中选择 Settings->Developer settings->OAuth Apps 进入 OAuth Apps 页面。
- 点击 New OAuth App 按钮,填入以下信息:
- Application name:应用程序名称;
- Homepage URL:应用程序主页的 URL;
- Authorization callback URL:社交登录认证成功后的回调 URL。
填写完成后点击 Register application 按钮。
- 生成应用程序的 Client ID 和 Client Secret。
三、实现社交登录
- 首先,在应用程序的登录页面中添加社交登录按钮,并将其链接到 Socialite 的 GitHub 认证服务中:
<a href="{{ url('/auth/github') }}">使用GitHub登录</a>
- 在 Laravel 中创建 GitHub 登录路由。打开
routes/web.php
文件并添加以下路由定义:
Route::get('auth/github', 'AuthLoginController@redirectToProvider'); Route::get('auth/github/callback', 'AuthLoginController@handleProviderCallback');
这里要求我们通过 redirectToProvider
将用户重定向到 GitHub 认证服务,并在那里完成登录认证。当认证成功后,GitHub 认证服务将重定向到指定的回调 URL auth/github/callback
,并通过该 URL 在 Session 中传递认证成功的用户信息。
- 构建
redirectToProvider
函数。打开app/Http/Controllers/Auth/LoginController.php
文件,并添加以下实现方式:
namespace AppHttpControllersAuth; use IlluminateHttpRequest; use AppHttpControllersController; use Socialite; class LoginController extends Controller { // ... public function redirectToProvider() { return Socialite::driver('github')->redirect(); } // ... }
我们调用 Socialite
中的 driver()
方法来获取 GitHub 认证驱动程序的实例,并使用 redirect()
方法将用户重定向到登录认证服务。
- 接下来,我们将在
handleProviderCallback
方法中处理认证成功后的回调。打开app/Http/Controllers/Auth/LoginController.php
文件,并添加以下方法:
// ... public function handleProviderCallback() { try { $user = Socialite::driver('github')->user(); } catch (Exception $e) { return redirect('/login'); } // 验证用户信息并完成登录,代码省略 // ... } // ...
我们使用 Socialite
中的 user()
方法获取 GitHub 认证服务返回的用户信息。如果在认证过程中有任何错误,我们将重定向用户到应用程序的登录页面。如果认证成功,则可以使用 $user
config/app.php
: rrreee# 🎜🎜# Puis dans Ajouter l'alias de façade Socialite au fichier config/app.php
:
De cette façon, nous avons réussi à installer le composant Socialite.
#🎜🎜# 2. Créez une application de connexion sociale #🎜🎜##🎜🎜#Socialite peut prendre en charge de nombreuses applications de connexion sociale différentes, et nous devons créer une application pour chaque application. Ce qui suit utilise GitHub comme exemple pour démontrer la création d'une nouvelle application OAuth sur GitHub. #🎜🎜#- Tout d'abord, connectez-vous à votre compte GitHub, sélectionnez Paramètres->Paramètres du développeur->Applications OAuth dans le menu déroulant de l'avatar pour accéder à la page Applications OAuth.

- Nom de l'application : nom de l'application
- URL de la page d'accueil : l'URL de la page d'accueil de l'application ;
- URL de rappel d'autorisation : l'URL de rappel après une authentification de connexion sociale réussie.

- Générer l'ID client et le secret client de l'application.

- Tout d'abord, ajoutez un bouton de connexion sociale à la page de connexion de l'application et associez-le au service d'authentification GitHub de Socialite : ol>rrreee
- Créer une route de connexion GitHub dans Laravel. Ouvrez le fichier
routes/web.php
et ajoutez la définition de route suivante : - Créez la fonction
redirectToProvider
. Ouvrez le fichierapp/Http/Controllers/Auth/LoginController.php
et ajoutez l'implémentation suivante : - Ensuite, nous gérerons le rappel après une authentification réussie dans la méthode
handleProviderCallback
. Ouvrez le fichierapp/Http/Controllers/Auth/LoginController.php
et ajoutez la méthode suivante :
redirectToProvider Service d'authentification GitHub et complétez l'authentification de connexion ici. Une fois l'authentification réussie, le service d'authentification GitHub redirigera vers l'URL de rappel spécifiée <code>auth/github/callback
et transmettra les informations utilisateur authentifiées avec succès dans la session via cette URL. #🎜🎜#Socialite
La méthode driver()
dans le pilote d'authentification GitHub est utilisée pour obtenir une instance du pilote d'authentification GitHub, et la méthode redirect()
est utilisée pour rediriger l'utilisateur vers le service d'authentification de connexion. #🎜🎜#Socialite
La méthode user()
obtient les informations utilisateur renvoyées par le service d'authentification GitHub. S'il y a des erreurs lors du processus d'authentification, nous redirigerons l'utilisateur vers la page de connexion de l'application. Si l'authentification réussit, les informations contenues dans l'objet $user
peuvent être utilisées pour authentifier l'utilisateur et terminer l'opération de connexion. #🎜🎜##🎜🎜#4. Résumé#🎜🎜##🎜🎜#À ce stade, nous avons terminé le processus d'utilisation de Laravel Socialite pour implémenter la connexion sociale GitHub. Grâce à une configuration simple et au code nécessaire, nous pouvons facilement implémenter plusieurs méthodes de connexion sociale, en ajoutant quelques fonctionnalités petites mais utiles à l'application, dont l'utilisation est recommandée dans des projets réels. #🎜🎜#
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Les opérations de base de données en PHP sont simplifiées à l'aide d'ORM, qui mappe les objets dans des bases de données relationnelles. EloquentORM dans Laravel vous permet d'interagir avec la base de données en utilisant une syntaxe orientée objet. Vous pouvez utiliser ORM en définissant des classes de modèle, en utilisant des méthodes Eloquent ou en créant un système de blog dans la pratique.

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.

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 ?

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

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.

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.

Guide des tests unitaires et d'intégration PHP Tests unitaires : concentrez-vous sur une seule unité de code ou de fonction et utilisez PHPUnit pour créer des classes de cas de test à des fins de vérification. Tests d'intégration : faites attention à la façon dont plusieurs unités de code fonctionnent ensemble et utilisez les méthodes setUp() et TearDown() de PHPUnit pour configurer et nettoyer l'environnement de test. Cas pratique : utilisez PHPUnit pour effectuer des tests unitaires et d'intégration dans les applications Laravel, notamment la création de bases de données, le démarrage de serveurs et l'écriture de code de test.

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.
