Table of Contents
Step 1: Create a Github application
Step 2: Install Laravel Socialite
Step 3: Configure the service provider and Facade Reference
Step 4: Define Github driver configuration
Step 5: Define Github login link
Step 6: Define the Github callback function
Step 7: Create the .env file
Home PHP Framework Laravel Laravel development: How to use Laravel Socialite to implement Github login?

Laravel development: How to use Laravel Socialite to implement Github login?

Jun 13, 2023 pm 02:46 PM
laravel github socialite

In today's Internet era, user login has become something that most web applications must consider. This also means that web applications need to provide users with optional multiple login methods to reduce user login difficulty and optimize user experience.

As one of the most popular PHP frameworks currently, Laravel provides some very convenient ways to implement user authentication. Laravel Socialite is a very powerful user authentication solution that allows applications to use Third-party platforms act as authentication providers.

In this article, we will introduce how to use Laravel Socialite to implement the Github login function. Let's take a step-by-step approach to achieving this goal.

Step 1: Create a Github application

Before starting this article, you first need to register and create a Github account, and create an OAuth application in Github. The process of creating an application is relatively simple, just follow the following steps:

  1. Log in to your Github account and create a new OAuth App in the Github Settings -> Developer settings -> OAuth Apps page
  2. Fill in the App name, Homepage URL and Callback URL in the first part

    Callback URL is the website address returned after successful login and needs to be defined in the Laravel website background

  3. The client_id and client_secret of the Github application will be displayed on the page returned after submitting the form. client_id will be used to configure Laravel Socialite's Github driver.

Step 2: Install Laravel Socialite

Installing Laravel Socialite can be easily done through Composer. Just enter the following instructions in the command line in the project directory:

composer require laravel/socialite
Copy after login

Step 3: Configure the service provider and Facade Reference

Open the config/app.php configuration file and find providers Arrays and aliases array, add the Socialite service provider and Facade references to the corresponding arrays.

'providers' => [
    // Other service providers...

    LaravelSocialiteSocialiteServiceProvider::class,
],

'aliases' => [
    // Other aliases...

    'Socialite' => LaravelSocialiteFacadesSocialite::class,
],
Copy after login

Step 4: Define Github driver configuration

Add the following configuration in the config/services.php configuration file:

'github' => [
    'client_id' => env('GITHUB_CLIENT_ID'),
    'client_secret' => env('GITHUB_CLIENT_SECRET'),
    'redirect' => env('GITHUB_REDIRECT'),
],
Copy after login

Open the blade template file of the login page and add the following code:

<a href="{{ url('auth/github') }}" class="btn btn-github"><i class="fa fa-github"></i> Github 登录</a>
Copy after login

This will create a link that will jump to the Github login page by accessing /auth/github.

Step 6: Define the Github callback function

Open the Callback URL page when we registered in Github and get the code parameter in the link, and add the following code in the Laravel route:

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');
});
Copy after login

What needs to be noted here is that we need to save github_id in the database for login verification when needed, and also save the user's nickname and avatar for easy display.

Step 7: Create the .env file

Open the .env file in the project root directory and add the following Github related configuration:

GITHUB_CLIENT_ID=your-github-client-id-here
GITHUB_CLIENT_SECRET=your-github-client-secret-here
GITHUB_REDIRECT=http://localhost:8000/auth/github/callback
Copy after login

In the above configuration, you need to # Replace ##your-github-client-id-here and your-github-client-secret-here with the client_id and client_secret you obtained from Github. The value of GITHUB_REDIRECT should be the redirect URI parameter when registering the application on Github.

Okay, now you can try logging in with Github to test your application. When you visit /auth/github, you should be redirected to Github's login page. After entering your Github account, you should be redirected back to the address you specified via the Callback URI.

Using Laravel Socialite is indeed a fast and easy way to implement authentication. It also supports many other account authentication service providers, such as Facebook, Twitter, Google, etc. Comfortable and efficient third-party login methods can greatly improve user experience, and adding multiple login methods to web applications has gradually become a necessity. Compared with implementing an authentication system independently, using Laravel Socialite can make use of existing excellent authentication service providers to simplify the implementation of identity authentication solutions.

The above is the detailed content of Laravel development: How to use Laravel Socialite to implement Github login?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to get the return code when email sending fails in Laravel? How to get the return code when email sending fails in Laravel? Apr 01, 2025 pm 02:45 PM

Method for obtaining the return code when Laravel email sending fails. When using Laravel to develop applications, you often encounter situations where you need to send verification codes. And in reality...

Laravel schedule task is not executed: What should I do if the task is not running after schedule: run command? Laravel schedule task is not executed: What should I do if the task is not running after schedule: run command? Mar 31, 2025 pm 11:24 PM

Laravel schedule task run unresponsive troubleshooting When using Laravel's schedule task scheduling, many developers will encounter this problem: schedule:run...

In Laravel, how to deal with the situation where verification codes are failed to be sent by email? In Laravel, how to deal with the situation where verification codes are failed to be sent by email? Mar 31, 2025 pm 11:48 PM

The method of handling Laravel's email failure to send verification code is to use Laravel...

How to implement the custom table function of clicking to add data in dcat admin? How to implement the custom table function of clicking to add data in dcat admin? Apr 01, 2025 am 07:09 AM

How to implement the table function of custom click to add data in dcatadmin (laravel-admin) When using dcat...

Laravel Redis connection sharing: Why does the select method affect other connections? Laravel Redis connection sharing: Why does the select method affect other connections? Apr 01, 2025 am 07:45 AM

The impact of sharing of Redis connections in Laravel framework and select methods When using Laravel framework and Redis, developers may encounter a problem: through configuration...

Laravel multi-tenant extension stancl/tenancy: How to customize the host address of a tenant database connection? Laravel multi-tenant extension stancl/tenancy: How to customize the host address of a tenant database connection? Apr 01, 2025 am 09:09 AM

Custom tenant database connection in Laravel multi-tenant extension package stancl/tenancy When building multi-tenant applications using Laravel multi-tenant extension package stancl/tenancy,...

Laravel database migration encounters duplicate class definition: How to resolve duplicate generation of migration files and class name conflicts? Laravel database migration encounters duplicate class definition: How to resolve duplicate generation of migration files and class name conflicts? Apr 01, 2025 pm 12:21 PM

A problem of duplicate class definition during Laravel database migration occurs. When using the Laravel framework for database migration, developers may encounter "classes have been used...

How to effectively check the validity of Redis connections in Laravel6 project? How to effectively check the validity of Redis connections in Laravel6 project? Apr 01, 2025 pm 02:00 PM

How to check the validity of Redis connections in Laravel6 projects is a common problem, especially when projects rely on Redis for business processing. The following is...

See all articles