composer require laravel/socialite
<a href="{{ url('auth/github') }}" class="btn btn-github"><i class="fa fa-github"></i> Github 登录</a>



Laravel-Entwicklung: Wie verwende ich Laravel Socialite, um die Github-Anmeldung zu implementieren?
Im heutigen Internetzeitalter ist die Benutzeranmeldung zu etwas geworden, das die meisten Webanwendungen berücksichtigen müssen. Dies bedeutet auch, dass Webanwendungen den Benutzern optional mehrere Anmeldemethoden bieten müssen, um die Schwierigkeiten bei der Benutzeranmeldung zu verringern und die Benutzererfahrung zu optimieren.
Als eines der derzeit beliebtesten PHP-Frameworks bietet Laravel einige sehr praktische Möglichkeiten zur Implementierung der Benutzerauthentifizierung. Laravel Socialite ist eine sehr leistungsstarke Benutzerauthentifizierungslösung, die es Anwendungen ermöglicht, Plattformen von Drittanbietern als Authentifizierungsanbieter zu verwenden.
In diesem Artikel stellen wir vor, wie Sie Laravel Socialite verwenden, um die Github-Anmeldefunktion zu implementieren. Gehen wir Schritt für Schritt vor, um dieses Ziel zu erreichen.
Schritt 1: Erstellen Sie eine Github-Anwendung
Bevor Sie mit diesem Artikel beginnen, müssen Sie sich zunächst registrieren, ein Github-Konto erstellen und eine OAuth-Anwendung in Github erstellen. Der Prozess zum Erstellen einer Anwendung ist relativ einfach. Befolgen Sie einfach die folgenden Schritte:
- Melden Sie sich bei Ihrem Github-Konto an und erstellen Sie eine neue OAuth-App in den Github-Einstellungen –> In der App im ersten Teil Name, Homepage-URL und Rückruf-URL
- Die Rückruf-URL ist die Website-Adresse, die nach erfolgreicher Anmeldung zurückgegeben wird. Sie muss im Hintergrund der Laravel-Website definiert werden
Die client_id und client_secret der Github-Anwendung werden sein wird auf der Seite angezeigt, die nach dem Absenden des Formulars zurückgegeben wird. client_id wird verwendet, um den Github-Treiber von Laravel Socialite zu konfigurieren.
- Schritt 2: Laravel Socialite installieren
composer require laravel/socialite
Nach dem Login kopieren
Schritt 3: Dienstanbieter und Fassadenreferenz konfigurierenÖffnen Sie die Konfigurationsdatei config/app.php, suchen Sie das Provider-Array und das Aliase-Array und fügen Sie Socialite hinzu Service-Provider- und Facade-Referenzen werden den entsprechenden Arrays hinzugefügt. composer require laravel/socialite
'providers' => [
// Other service providers...
LaravelSocialiteSocialiteServiceProvider::class,
],
'aliases' => [
// Other aliases...
'Socialite' => LaravelSocialiteFacadesSocialite::class,
],
Nach dem Login kopieren
Schritt 4: Github-Treiberkonfiguration definierenFügen Sie die folgende Konfiguration in der Konfigurationsdatei config/services.php hinzu:'providers' => [ // Other service providers... LaravelSocialiteSocialiteServiceProvider::class, ], 'aliases' => [ // Other aliases... 'Socialite' => LaravelSocialiteFacadesSocialite::class, ],
'github' => [
'client_id' => env('GITHUB_CLIENT_ID'),
'client_secret' => env('GITHUB_CLIENT_SECRET'),
'redirect' => env('GITHUB_REDIRECT'),
],
Nach dem Login kopieren
Schritt 5: Github-Anmeldelink definierenÖffnen Sie die Blade-Vorlagendatei der Anmeldeseite und fügen Sie die hinzu Folgender Code:'github' => [ 'client_id' => env('GITHUB_CLIENT_ID'), 'client_secret' => env('GITHUB_CLIENT_SECRET'), 'redirect' => env('GITHUB_REDIRECT'), ],
<a href="{{ url('auth/github') }}" class="btn btn-github"><i class="fa fa-github"></i> Github 登录</a>
Nach dem Login kopieren
Dadurch wird ein Link erstellt, der durch Zugriff auf /auth/github zur Github-Anmeldeseite springt. Schritt 6: Definieren Sie die Github-Rückruffunktion. Öffnen Sie die Rückruf-URL-Seite, als wir uns in Github registriert haben, rufen Sie den Codeparameter im Link ab und fügen Sie den folgenden Code in die Laravel-Route ein: <a href="{{ url('auth/github') }}" class="btn btn-github"><i class="fa fa-github"></i> Github 登录</a>
Route::get('auth/github/callback', function () {
$user = Socialite::driver('github')->user();
// 如果在本地没有找到该用户,则创建新用户
$existingUser = User::where('email', $user->getEmail())->first();
if ($existingUser) {
auth()->login($existingUser, true);
} else {
$newUser = new User;
$newUser->name = $user->getNickname();
$newUser->email = $user->getEmail();
$newUser->github_id = $user->getId();
$newUser->avatar = $user->getAvatar();
$newUser->provider = 'github';
$newUser->save();
auth()->login($newUser, true);
}
return redirect()->to('/home');
});
Nach dem Login kopieren
Hier sollte beachtet werden Wir müssen github_id in der Datenbank speichern, um bei Bedarf die Anmeldung zu überprüfen, und außerdem den Spitznamen und den Avatar des Benutzers speichern, um die Anzeige zu erleichtern. Schritt 7: Erstellen Sie die .env-DateiÖffnen Sie die .env-Datei im Stammverzeichnis des Projekts und fügen Sie die folgende Github-bezogene Konfiguration hinzu: Route::get('auth/github/callback', function () { $user = Socialite::driver('github')->user(); // 如果在本地没有找到该用户,则创建新用户 $existingUser = User::where('email', $user->getEmail())->first(); if ($existingUser) { auth()->login($existingUser, true); } else { $newUser = new User; $newUser->name = $user->getNickname(); $newUser->email = $user->getEmail(); $newUser->github_id = $user->getId(); $newUser->avatar = $user->getAvatar(); $newUser->provider = 'github'; $newUser->save(); auth()->login($newUser, true); } return redirect()->to('/home'); });
GITHUB_CLIENT_ID=your-github-client-id-here
GITHUB_CLIENT_SECRET=your-github-client-secret-here
GITHUB_REDIRECT=http://localhost:8000/auth/github/callback
Nach dem Login kopieren
In der obigen Konfiguration müssen Sie GITHUB_CLIENT_ID=your-github-client-id-here GITHUB_CLIENT_SECRET=your-github-client-secret-here GITHUB_REDIRECT=http://localhost:8000/auth/github/callback
durch die erhaltene client_id und client_secret ersetzen von Github. Der Wert von GITHUB_REDIRECT sollte der Umleitungs-URI-Parameter sein, wenn die Anwendung auf Github registriert wird.
Okay, jetzt können Sie versuchen, sich mit Github anzumelden, um Ihre Anwendung zu testen. Wenn Sie /auth/github besuchen, sollten Sie zur Anmeldeseite von Github weitergeleitet werden. Nach der Eingabe Ihres Github-Kontos sollten Sie zurück zu der Adresse weitergeleitet werden, die Sie über den Callback-URI angegeben haben. your-github-client-id-here
和 your-github-client-secret-here
Das obige ist der detaillierte Inhalt vonLaravel-Entwicklung: Wie verwende ich Laravel Socialite, um die Github-Anmeldung zu implementieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



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.

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

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.

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 – 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?

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.

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.

Laut Nachrichten dieser Website vom 27. Juni wurde die von CSDN gestartete Open-Source-Code-Hosting-Plattform GitCode kürzlich Batch-Transfers von Github-Projekten ausgesetzt. Sie ersetzte sogar die Github-Adresse in der Readme-Datei im Originalprojekt durch GitCode und auch „ intimately“ hat ein gleichnamiges Konto für Entwickler registriert. . In der offiziellen GitCode-Community gab es von gestern bis heute mehrere Probleme, die eine sofortige Löschung portierter Projekte und Benutzer forderten, und es gab Antworten von Community-Mitgliedern. Als Reaktion auf die Löschanfragen der Entwickler äußerte ein offizielles Mitglied der GitCode-Community namens XXM gestern in der Ausgabe eine Entschuldigung und erklärte direkt, dass das Projekt und die Organisation wie gewünscht gelöscht wurden. Der Entwickler stellte jedoch fest, dass die Organisation weiterhin durchsucht werden konnte, und bezweifelte, dass es sich nur um einen vorübergehenden Bildschirm handelte.
