Heim > PHP-Framework > Laravel > Laravel-Entwicklung: Wie implementiert man die Anmeldung von Drittanbietern mit Laravel Socialite und Google?

Laravel-Entwicklung: Wie implementiert man die Anmeldung von Drittanbietern mit Laravel Socialite und Google?

PHPz
Freigeben: 2023-06-14 09:30:25
Original
1733 Leute haben es durchsucht

Laravel-Entwicklung: Wie implementiert man die Anmeldung von Drittanbietern mit Laravel Socialite und Google?

In modernen Webanwendungen sind Benutzeranmeldung und -authentifizierung unerlässlich. Die traditionelle Authentifizierungsmethode basierend auf Benutzername und Passwort kann ihren Sicherheits- und Komfortanforderungen nicht mehr gerecht werden. Die Drittanbieter-Anmeldung löst dieses Problem, indem sie es Benutzern ermöglicht, sich mit Konten, die sie bereits auf anderen Plattformen erstellt haben, bei Ihrer App anzumelden.

In diesem Artikel stellen wir vor, wie Sie die Drittanbieter-Anmeldung mit Laravel Socialite und Google implementieren.

Was ist Laravel Socialite?

Laravel Socialite ist eine Paketbibliothek für den OAuth-Authentifizierungsprozess, der in der Laravel-Community weit verbreitet ist. Es ermöglicht uns die einfache Verbindung mit mehreren Drittanbieterdiensten wie Facebook, Twitter, Google usw.

Einrichtung der Google Development Platform

Zuerst müssen wir die OAuth-Client-ID in der Google Development Platform erstellen. Öffnen Sie https://console.developers.google.com/ und erstellen Sie ein neues Projekt. Klicken Sie im Dropdown-Menü „Projekt auswählen“ in der oberen linken Ecke auf „Neues Projekt“.

Geben Sie den Projektnamen und andere Projekteinstellungsinformationen ein. Nach dem Erstellen eines Projekts werden Sie zur Übersichtsseite des Projekts weitergeleitet. Wählen Sie im oberen Menü APIs & Dienste > Anmeldeinformationen aus.

Klicken Sie auf die Schaltfläche „Anmeldeinformationen erstellen“ und wählen Sie „OAuth-Client-ID“.

Wählen Sie im Dropdown-Menü „Anwendungstyp“ die Option „Webanwendung“ aus. Um Laravel Socialite mit Google zu integrieren, müssen wir die Felder „Autorisierte JavaScript-Quelle“ und „Umleitungs-URI“ ausfüllen.

Geben Sie im Feld „Autorisierte JavaScript-Quellen“ den Hostnamen Ihrer Anwendung ein. Wir können die URL „http://localhost“ lokal verwenden. Geben Sie im Feld „Umleitungs-URI“ eine Rückruf-URL ein, um nach der Anmeldung bei Google zurück zu Ihrer Anwendung umzuleiten. In diesem Beispiel verwenden wir die URL „http://localhost:8000/auth/google/callback“.

Nach der Erstellung erhalten Sie eine Client-ID und ein Client-Geheimnis. Speichern Sie diese Anmeldeinformationen, wir werden sie später in Laravel verwenden.

Laravel Socialite-Installation und -Konfiguration

Laravel Socialite ist ein Composer-Paket, das über die Befehlszeileninstallation verwendet werden kann. Wir verwenden den folgenden Befehl, um es zu installieren:

composer require laravel/socialite
Nach dem Login kopieren

Nach Abschluss der Installation fügen Sie den Socialite-Dienstanbieter in der Laravel-Konfigurationsdatei hinzu:

'providers' => [
    // ...
    LaravelSocialiteSocialiteServiceProvider::class,
],
Nach dem Login kopieren

Sie müssen außerdem die folgenden Konfigurationsinformationen zur Laravel-Konfigurationsdatei hinzufügen:

'client_id' => env('GOOGLE_CLIENT_ID'),
'client_secret' => env('GOOGLE_CLIENT_SECRET'),
'redirect' => env('GOOGLE_REDIRECT'),
Nach dem Login kopieren

Hier haben wir die Datei .env verwendet, die die erforderlichen Konfigurationsinformationen enthält: .env文件保存需要的配置信息:

GOOGLE_CLIENT_ID=your-client-id
GOOGLE_CLIENT_SECRET=your-client-secret
GOOGLE_REDIRECT=http://localhost:8000/auth/google/callback
Nach dem Login kopieren

Laravel Socialite集成

在这里,我们需要创建一个路由处理程序,它将处理与Google的OAuth流程。

Route::get('/auth/google', function () {
    return Socialite::driver('google')->redirect();
});

Route::get('/auth/google/callback', function () {
    $user = Socialite::driver('google')->user();
    dd($user);
});
Nach dem Login kopieren

第一个路由处理程序将重定向用户到Google登录流程。

在成功后,用户将被重定向到第二个路由处理程序中。 此时,我们可以使用user()

$user = Socialite::driver('google')->user();
dd($user);
Nach dem Login kopieren

Laravel Socialite-Integration

Hier müssen wir einen Routenhandler erstellen, der den OAuth-Fluss mit Google abwickelt.

Route::get('/auth/google/callback', function () {
    $user = Socialite::driver('google')->user();
    // save application user
    $authUser = User::where('email', $user->email)->first();
    if ($authUser) {
        Auth::login($authUser, true);
        return redirect('/home');
    }
    // create application user
    $newUser = new User;
    $newUser->name = $user->name;
    $newUser->email = $user->email;
    $newUser->password = bcrypt(str_random(16));
    $newUser->save();
    Auth::login($newUser, true);
    return redirect('/home');
});
Nach dem Login kopieren
Der erste Routenhandler leitet den Benutzer zum Google-Anmeldefluss weiter.

Bei Erfolg wird der Benutzer zum zweiten Routenhandler weitergeleitet. An dieser Stelle können wir die Methode user() verwenden, um die Informationen des angemeldeten Benutzers abzurufen. Geben Sie den zurückgegebenen Benutzercode ein und drucken Sie die erhaltenen Benutzerinformationen aus:

rrreee

Sie sehen weitere Daten über den Benutzer, wie Benutzername, E-Mail-Adresse, Avatar, Token usw. Basierend auf diesen Informationen können wir die Drittanbieter-Anmeldung implementieren.

Hier verwenden wir die oben erhaltenen Benutzerinformationen, um den Anwendungsbenutzer zu erstellen und zu authentifizieren.

rrreee

Hier beginnen wir damit, bestehende App-Benutzer mithilfe der von Google zurückgegebenen E-Mail-Adressen zu finden. Wenn es gefunden wird, melden Sie sich mit der Authentifizierungs-API von Laravel an. Wenn nicht gefunden, erstellen Sie einen neuen Benutzer und melden Sie sich mit der Authentifizierungs-API von Laravel an.

Fazit🎜🎜In diesem Artikel wird erläutert, wie Sie die Anmeldung von Drittanbietern mit Laravel Socialite und Google implementieren. 🎜🎜Durch die Einrichtung der Google Dev Platform haben wir die erforderlichen OAuth-Anmeldeinformationen generiert. Dann haben wir Laravel Socialite verwendet, um die mühsamen Schritte und den Code im OAuth-Prozess zu eliminieren. Abschließend authentifizieren wir uns und erstellen einen neuen Benutzer unter Verwendung der vorhandenen E-Mail-Adresse des Benutzers. 🎜🎜Wir hoffen, dass dieser Artikel eine Anleitung zur Implementierung der Drittanbieter-Anmeldung mit Laravel Socialite und Google bietet und einen Überblick über den OAuth-Prozess bietet. 🎜

Das obige ist der detaillierte Inhalt vonLaravel-Entwicklung: Wie implementiert man die Anmeldung von Drittanbietern mit Laravel Socialite und Google?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage