Heim PHP-Framework Laravel So verwenden Sie Laravel, um die Anmeldefunktion eines Drittanbieters zu implementieren

So verwenden Sie Laravel, um die Anmeldefunktion eines Drittanbieters zu implementieren

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

So verwenden Sie Laravel, um die Anmeldefunktion eines Drittanbieters zu implementieren

Mit der kontinuierlichen Weiterentwicklung der Internettechnologie haben die Menschen in den letzten Jahren immer höhere Anforderungen an die Sicherheit und Benutzererfahrung von Websites oder Anwendungen gestellt. Um die Benutzerregistrierung und -anmeldung zu erleichtern, ist die Anmeldung bei Drittanbieterkonten zu einer der am häufigsten verwendeten Funktionen in Websites und Anwendungen geworden. Als beliebtes PHP-Framework bietet Laravel eine praktische Social-Login-Autorisierungsfunktion, wodurch es besonders bequem ist, Anmeldefunktionen von Drittanbietern zu implementieren. In diesem Artikel wird erläutert, wie Sie Laravel zum Implementieren der Anmeldefunktion eines Drittanbieters verwenden, und einige Implementierungscodes als Referenz für die Leser bereitstellen.

1. Dienstanbieterinformationen konfigurieren

In Laravel können wir das Social-Login-Autorisierungspaket socialite verwenden, um die Drittanbieter-Login-Funktion zu implementieren. socialite unterstützt eine Vielzahl autorisierter Dienstanbieter, darunter Facebook, Google, Twitter, WeChat usw. Bevor wir socialite zur Implementierung der Drittanbieter-Anmeldefunktion verwenden, müssen wir daher die Dienstanbieterinformationen konfigurieren. 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',
],
Nach dem Login kopieren

其中,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();
});
Nach dem Login kopieren

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

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

Route::get('login/github/callback', function () {
    $user = Socialite::driver('github')->user();
    // 处理用户信息
});
Nach dem Login kopieren

其中,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);
    }
}
Nach dem Login kopieren

四、使用扩展包

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

  1. 安装laravel/socialite

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

composer require laravel/socialite
Nach dem Login kopieren
  1. 配置服务商信息

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

'github' => [
    'client_id' => env('GITHUB_CLIENT_ID'),
    'client_secret' => env('GITHUB_CLIENT_SECRET'),
    'redirect' => '/auth/github/callback',
],
Nach dem Login kopieren
  1. 创建授权路由

routes/web.php

Am Beispiel von GitHub können wir durch Erstellen und Autorisieren einer OAuth-Anwendung die Client-ID und den Client-Schlüssel erhalten. Die spezifische Methode, es zu erhalten, ist wie folgt: 🎜
  1. Besuchen Sie die Website von GitHub und melden Sie sich bei Ihrem Konto an.
  2. Gehen Sie zur Einstellungsseite von GitHub, wählen Sie die Registerkarte „Entwicklereinstellungen“, klicken Sie auf „OAuth-Apps“ und wählen Sie dann „Neue OAuth-App“ aus.
  3. Geben Sie die detaillierten Informationen zur Anwendung ein, einschließlich Anwendungsname, URL der Anwendungshomepage, Autorisierungsrückruf-URL usw.
  4. Senden Sie den Antrag und erstellen Sie ihn. Nach erfolgreicher Erstellung sind Informationen wie die Client-ID und der Client-Key der Anwendung auf der GitHub-Seite zu finden.
🎜Mit diesen Informationen können wir eine Laravel-Konfigurationsdatei mit dem Namen /config/services.php erstellen und ihr den folgenden Inhalt hinzufügen: 🎜
Route::get('/auth/github', 'AuthLoginController@GitHub');
Nach dem Login kopieren
Nach dem Login kopieren
🎜 Darunter github ist der Name des Dienstanbieters, den wir verwenden möchten, client_id und client_secret sind die Kunden, die wir bei der Beantragung der OAuth-Anwendung erhalten haben. Die Client-ID und Client-Geheimnis, redirect ist die OAuth-Rückruf-URL, also die Autorisierungs-Rückruf-URL, die wir beim Erstellen der Anwendung eingegeben haben. Hier setzen wir es auf localhost:8000/login/github/callback. Wir werden diese Route später in der Routing-Datei erstellen. 🎜🎜2. Erstellen Sie eine Route🎜🎜Als nächstes müssen wir eine Route in der Routing-Datei der Laravel-Anwendung erstellen, um die Funktion der Anmeldung über GitHub zu implementieren. Hier können wir die Route-Klasse von Laravel verwenden, um Routen zu erstellen. 🎜🎜Im ersten Schritt müssen wir eine Autorisierungs-Umleitungsroute erstellen, die für die Weiterleitung von Benutzern zur GitHub-Anmeldeseite verantwortlich ist. Fügen Sie den folgenden Code in die Routing-Datei ein: 🎜
Route::get('/auth/github/callback', 'AuthLoginController@GitHubCallback');
Nach dem Login kopieren
Nach dem Login kopieren
🎜 Unter anderem ruft Socialite::driver('github') die driver-Methode von socialite</ auf. Code> Autorisierungspaket, rufen Sie die Instanz des GitHub-Dienstanbieters ab. Die Methode <code>redirect implementiert den OAuth-Autorisierungssprung und leitet den Benutzer zur Authentifizierungs- und Autorisierungsseite von GitHub weiter. 🎜🎜Im zweiten Schritt erstellen wir eine Autorisierungs-Callback-Route, die dafür verantwortlich ist, die vom GitHub-Dienstanbieter zurückgegebenen Benutzerinformationen abzurufen und zu verarbeiten. Fügen Sie den folgenden Code in die Routing-Datei ein: 🎜
use Socialite;

class LoginController extends Controller
{

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

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

}
Nach dem Login kopieren
Nach dem Login kopieren
🎜 Unter anderem ruft Socialite::driver('github') die Methode driver von socialite</ auf. Code> Autorisierungspaket, rufen Sie die Instanz des GitHub-Dienstanbieters ab. Die <code>user-Methode implementiert den Prozess zum Abrufen von Benutzerinformationen durch OAuth-Autorisierung. Sie ruft die Benutzerinformationen vom GitHub-Dienstanbieter ab, die in Form von $user</code gespeichert werden > Variable zurück. 🎜🎜Nachdem wir die Variable <code>$user erhalten haben, können wir die Benutzerinformationen verarbeiten. Da das Format der von den einzelnen Drittanbietern zurückgegebenen Benutzerinformationen leicht unterschiedlich ist, gehen wir hier nicht näher darauf ein. 🎜🎜3. Erstellen Sie öffentliche Methoden🎜🎜Um die Verwaltung und Verwendung zu erleichtern, können wir eine GitHub-Methode in der app/Http/Controllers/Auth/LoginController.php erstellen Controller für andere aufzurufende Methoden. 🎜🎜Bei dieser Methode müssen wir zunächst die Methode Socialite::driver('github')->redirect() verwenden, um den Benutzer zur GitHub-Anmeldeseite umzuleiten. Während des Rückrufprozesses zum Abrufen von Benutzerinformationen können wir Benutzerinformationen in der Methode GitHubCallback verarbeiten. 🎜🎜Das Folgende ist ein grundlegender Beispielcode: 🎜rrreee🎜4. Verwenden Sie das Erweiterungspaket 🎜🎜Wenn Sie der Meinung sind, dass die obige Methode umständlich ist, können Sie das Erweiterungspaket für die Social-Login-Autorisierung laravel/socialite verwenden In diesem Erweiterungspaket wurden wichtige Dienstanbieter gekapselt und entsprechende Befehlszeilentools bereitgestellt, um autorisierte Dienstanbieter aufzubauen. 🎜
  1. Installieren Sie laravel/socialite
🎜Verwenden Sie Composer im Terminal, um das Erweiterungspaket laravel/socialite zu installieren: 🎜rrreee
  1. Dienstanbieterinformationen konfigurieren
🎜Fügen Sie in der Konfigurationsdatei von Laravel config/services.php die Dienstanbieterinformationen hinzu, die Sie verwenden müssen , wie folgt Nehmen Sie GitHub als Beispiel: 🎜rrreee
  1. Autorisierungsroute erstellen
🎜In der Routing-Datei routes/web.php , erstellen Sie eine verifizierte Autorisierungsroute: 🎜
Route::get('/auth/github', 'AuthLoginController@GitHub');
Nach dem Login kopieren
Nach dem Login kopieren
  1. 创建回调路由

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

Route::get('/auth/github/callback', 'AuthLoginController@GitHubCallback');
Nach dem Login kopieren
Nach dem Login kopieren
  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);
    }

}
Nach dem Login kopieren
Nach dem Login kopieren

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

总结:

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

Das obige ist der detaillierte Inhalt vonSo verwenden Sie Laravel, um die Anmeldefunktion eines Drittanbieters zu implementieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Vergleich der neuesten Versionen von Laravel und CodeIgniter Vergleich der neuesten Versionen von Laravel und CodeIgniter Jun 05, 2024 pm 05:29 PM

Die neuesten Versionen von Laravel 9 und CodeIgniter 4 bieten aktualisierte Funktionen und Verbesserungen. Laravel9 übernimmt die MVC-Architektur und bietet Funktionen wie Datenbankmigration, Authentifizierung und Template-Engine. CodeIgniter4 nutzt die HMVC-Architektur, um Routing, ORM und Caching bereitzustellen. In Bezug auf die Leistung sorgen das auf Dienstanbietern basierende Designmuster von Laravel9 und das leichte Framework von CodeIgniter4 für eine hervorragende Leistung. In praktischen Anwendungen eignet sich Laravel9 für komplexe Projekte, die Flexibilität und leistungsstarke Funktionen erfordern, während CodeIgniter4 für schnelle Entwicklung und kleine Anwendungen geeignet ist.

Wie vergleichen sich die Datenverarbeitungsfunktionen in Laravel und CodeIgniter? Wie vergleichen sich die Datenverarbeitungsfunktionen in Laravel und CodeIgniter? Jun 01, 2024 pm 01:34 PM

Vergleichen Sie die Datenverarbeitungsfunktionen von Laravel und CodeIgniter: ORM: Laravel verwendet EloquentORM, das eine relationale Klassen-Objekt-Zuordnung bereitstellt, während CodeIgniter ActiveRecord verwendet, um das Datenbankmodell als Unterklasse von PHP-Klassen darzustellen. Abfrage-Builder: Laravel verfügt über eine flexible verkettete Abfrage-API, während der Abfrage-Builder von CodeIgniter einfacher und Array-basiert ist. Datenvalidierung: Laravel bietet eine Validator-Klasse, die benutzerdefinierte Validierungsregeln unterstützt, während CodeIgniter über weniger integrierte Validierungsfunktionen verfügt und eine manuelle Codierung benutzerdefinierter Regeln erfordert. Praxisfall: Beispiel einer Benutzerregistrierung zeigt Lar

Was ist die GateToken(GT)-Währung? Einführung in die GT-Münzfunktionen und die Token-Ökonomie Was ist die GateToken(GT)-Währung? Einführung in die GT-Münzfunktionen und die Token-Ökonomie Jul 15, 2024 pm 04:36 PM

Was ist die GateToken(GT)-Währung? GT (GateToken) ist der native Vermögenswert in der GateChain-Kette und die offizielle Plattformwährung von Gate.io. Der Wert von GT-Münzen hängt eng mit der Entwicklung der Ökologie von Gate.io und GateChain zusammen. Was ist GateChain? GateChain wurde 2018 geboren und ist eine neue Generation leistungsstarker öffentlicher Ketten, die von Gate.io eingeführt wurde. GateChain konzentriert sich auf den Schutz der Sicherheit der On-Chain-Assets der Benutzer und die Bereitstellung bequemer dezentraler Transaktionsdienste. Das Ziel von GateChain besteht darin, ein sicheres und effizientes dezentrales Ökosystem für die Speicherung, Verteilung und Transaktion digitaler Assets auf Unternehmensebene aufzubauen. Gatechain hat Original

Laravel – Handwerkerbefehle Laravel – Handwerkerbefehle Aug 27, 2024 am 10:51 AM

Laravel – Artisan Commands – Laravel 5.7 bietet eine neue Möglichkeit, neue Befehle zu behandeln und zu testen. Es enthält eine neue Funktion zum Testen von Handwerkerbefehlen und die Demonstration wird unten erwähnt?

Was ist einsteigerfreundlicher: Laravel oder CodeIgniter? Was ist einsteigerfreundlicher: Laravel oder CodeIgniter? Jun 05, 2024 pm 07:50 PM

Für Anfänger bietet CodeIgniter eine sanftere Lernkurve und weniger Funktionen, deckt aber die Grundbedürfnisse ab. Laravel bietet einen größeren Funktionsumfang, weist jedoch eine etwas steilere Lernkurve auf. In Bezug auf die Leistung schneiden sowohl Laravel als auch CodeIgniter gut ab. Laravel verfügt über eine umfangreichere Dokumentation und aktive Community-Unterstützung, während CodeIgniter einfacher und leichtgewichtiger ist und über starke Sicherheitsfunktionen verfügt. Im praktischen Fall der Erstellung einer Blogging-Anwendung vereinfacht EloquentORM von Laravel die Datenmanipulation, während CodeIgniter mehr manuelle Konfiguration erfordert.

Laravel vs CodeIgniter: Welches Framework ist besser für große Projekte? Laravel vs CodeIgniter: Welches Framework ist besser für große Projekte? Jun 04, 2024 am 09:09 AM

Bei der Auswahl eines Frameworks für große Projekte haben Laravel und CodeIgniter jeweils ihre eigenen Vorteile. Laravel ist für Anwendungen auf Unternehmensebene konzipiert und bietet modularen Aufbau, Abhängigkeitsinjektion und einen leistungsstarken Funktionsumfang. CodeIgniter ist ein leichtes Framework, das sich eher für kleine bis mittelgroße Projekte eignet und Wert auf Geschwindigkeit und Benutzerfreundlichkeit legt. Für große Projekte mit komplexen Anforderungen und einer großen Anzahl von Benutzern sind die Leistung und Skalierbarkeit von Laravel besser geeignet. Für einfache Projekte oder Situationen mit begrenzten Ressourcen sind die leichten und schnellen Entwicklungsfunktionen von CodeIgniter idealer.

Laravel vs CodeIgniter: Welches Framework ist besser für kleine Projekte? Laravel vs CodeIgniter: Welches Framework ist besser für kleine Projekte? Jun 04, 2024 pm 05:29 PM

Für kleine Projekte eignet sich Laravel, für größere Projekte, die starke Funktionalität und Sicherheit erfordern. CodeIgniter eignet sich für sehr kleine Projekte, die geringes Gewicht und Benutzerfreundlichkeit erfordern.

Welche ist die bessere Template-Engine, Laravel oder CodeIgniter? Welche ist die bessere Template-Engine, Laravel oder CodeIgniter? Jun 03, 2024 am 11:30 AM

Vergleichen Sie Laravel's Blade und die Twig-Vorlagen-Engine von CodeIgniter und wählen Sie je nach Projektanforderungen und persönlichen Vorlieben: Blade basiert auf der MVC-Syntax, die eine gute Codeorganisation und Vorlagenvererbung fördert. Twig ist eine Bibliothek eines Drittanbieters, die flexible Syntax, leistungsstarke Filter, erweiterten Support und eine Sicherheits-Sandbox bietet.

See all articles