目錄
步驟1:建立Github應用程式
步驟2:安裝 Laravel Socialite
步驟3:設定服務提供者和Facade 引用
步驟4:定義Github驅動程式設定
步驟5:定義Github登入連結
步驟6:定義Github回呼函數
步驟7:建立.env檔案
首頁 php框架 Laravel Laravel開發:如何使用Laravel Socialite實現Github登入?

Laravel開發:如何使用Laravel Socialite實現Github登入?

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

在當今網路時代,使用者的登入已經成為了絕大部分網頁應用程式必須考慮的事情。這也意味著Web應用程式需要提供使用者可選擇的多重登入方式,來降低使用者的登入困難度和優化使用者體驗。

作為目前最受歡迎的PHP框架之一,Laravel提供了一些非常方便的方式來實現用戶的身份驗證,其中Laravel Socialite是一個非常強大的用戶身份驗證解決方案,它允許應用程式使用第三方平台作為身分驗證提供者。

在本文中,我們將介紹如何使用Laravel Socialite來實現Github登入的功能。下面我們就來逐步實現這個目標。

步驟1:建立Github應用程式

在開始本文之前,首先需要註冊並建立Github帳號,並且在Github中建立一個OAuth應用程式。建立應用程式的過程相對簡單,只需遵循以下步驟:

  1. 登陸Github帳號,在Github Settings -> Developer settings -> OAuth Apps頁面中建立新的OAuth App
  2. 在第一部分填入App名稱、Homepage URL和Callback URL

    Callback URL 即登陸成功後回傳的Website位址,需要在Laravel網站後台定義

  3. #提交表單後回傳的頁面中會顯示Github應用程式的client_id和client_secret。 client_id 將用於設定Laravel Socialite的Github驅動程式。

步驟2:安裝 Laravel Socialite

安裝 Laravel Socialite 可以透過Composer輕鬆完成。只需在專案目錄下的命令列中輸入以下指令:

composer require laravel/socialite
登入後複製

步驟3:設定服務提供者和Facade 引用

#開啟config/app.php 設定文件,找到providers陣列和aliases 數組,將Socialite 服務提供者和Facade 引用新增至對應的陣列。

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

    LaravelSocialiteSocialiteServiceProvider::class,
],

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

    'Socialite' => LaravelSocialiteFacadesSocialite::class,
],
登入後複製

步驟4:定義Github驅動程式設定

在config/services.php 設定檔中新增以下設定:

'github' => [
    'client_id' => env('GITHUB_CLIENT_ID'),
    'client_secret' => env('GITHUB_CLIENT_SECRET'),
    'redirect' => env('GITHUB_REDIRECT'),
],
登入後複製

步驟5:定義Github登入連結

開啟登入頁面的blade 範本文件,新增以下程式碼:

<a href="{{ url('auth/github') }}" class="btn btn-github"><i class="fa fa-github"></i> Github 登录</a>
登入後複製

這將建立一個鏈接,透過造訪/auth/github,將會跳到Github的登入頁面。

步驟6:定義Github回呼函數

開啟我們在Github中註冊時的Callback URL 頁面並取得連結中的code參數,並在Laravel路由中新增以下程式碼:

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_id保存在資料庫中以便需要時進行登入驗證,同時也保存了使用者暱稱和頭像方便展示。

步驟7:建立.env檔案

開啟專案根目錄下的.env 文件,新增以下Github 相關設定:

GITHUB_CLIENT_ID=your-github-client-id-here
GITHUB_CLIENT_SECRET=your-github-client-secret-here
GITHUB_REDIRECT=http://localhost:8000/auth/github/callback
登入後複製

上述設定中,你需要將your-github-client-id-hereyour-github-client-secret-here 被你自己在Github取得到的client_id和client_secret。 GITHUB_REDIRECT的值應該是Github上註冊應用程式時的重定向URI參數。

好了,現在你可以嘗試用 Github 登入來測試你的應用程式了。當你造訪 /auth/github 時,你應該會被重新導向到 Github 的登入頁面。輸入你的 Github 帳號後,你應該會被重新導向回到你透過 Callback URI 指定的位址。

使用 Laravel Socialite 確實是實現身份驗證的一種快速、簡單的方法,它還支援其他許多帳號認證服務供應商,如Facebook、Twitter、Google等等。舒適且有效率的第三方登入方式能夠大幅提升使用者的體驗,為網路應用程式增加多重登入方式也逐漸成為了必要。相較於自己獨立實現一套認證系統,使用 Laravel Socialite 則可以利用現有的優秀的認證服務提供者來簡化身分驗證方案的實作。

以上是Laravel開發:如何使用Laravel Socialite實現Github登入?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Laravel和CodeIgniter的最新版本對比 Laravel和CodeIgniter的最新版本對比 Jun 05, 2024 pm 05:29 PM

Laravel9和CodeIgniter4的最新版本提供了更新的功能和改進。 Laravel9採用MVC架構,提供資料庫遷移、驗證及模板引擎等功能。 CodeIgniter4採用HMVC架構,提供路由、ORM和快取。在性能方面,Laravel9的基於服務提供者設計模式和CodeIgniter4的輕量級框架使其具有出色的性能。在實際應用中,Laravel9適用於需要靈活性和強大功能的複雜項目,而CodeIgniter4適用於快速開發和小型應用程式。

Laravel 和 CodeIgniter 中資料處理能力的比較如何? Laravel 和 CodeIgniter 中資料處理能力的比較如何? Jun 01, 2024 pm 01:34 PM

比較Laravel和CodeIgniter的資料處理能力:ORM:Laravel使用EloquentORM,提供類別物件關係映射,而CodeIgniter使用ActiveRecord,將資料庫模型表示為PHP類別的子類別。查詢建構器:Laravel具有靈活的鍊式查詢API,而CodeIgniter的查詢建構器更簡單,基於陣列。資料驗證:Laravel提供了一個Validator類,支援自訂驗證規則,而CodeIgniter的驗證功能內建較少,需要手動編碼自訂規則。實戰案例:用戶註冊範例展示了Lar

Laravel - Artisan 指令 Laravel - Artisan 指令 Aug 27, 2024 am 10:51 AM

Laravel - Artisan 指令 - Laravel 5.7 提供了處理和測試新指令的新方法。它包括測試 artisan 命令的新功能,下面提到了演示?

Laravel 和 CodeIgniter 對於初學者來說哪一個比較友善? Laravel 和 CodeIgniter 對於初學者來說哪一個比較友善? Jun 05, 2024 pm 07:50 PM

對於初學者來說,CodeIgniter的學習曲線更平緩,功能較少,但涵蓋了基本需求。 Laravel提供了更廣泛的功能集,但學習曲線稍陡。在性能方面,Laravel和CodeIgniter都表現出色。 Laravel有更廣泛的文件和活躍的社群支持,而CodeIgniter更簡單、輕量級,具有強大的安全功能。在建立部落格應用程式的實戰案例中,Laravel的EloquentORM簡化了資料操作,而CodeIgniter需要更多的手動配置。

Laravel和CodeIgniter:哪種框架更適合大型專案? Laravel和CodeIgniter:哪種框架更適合大型專案? Jun 04, 2024 am 09:09 AM

在選擇大型專案框架時,Laravel和CodeIgniter各有優勢。 Laravel針對企業級應用程式而設計,提供模組化設計、相依性注入和強大的功能集。 CodeIgniter是一款輕量級框架,更適合小型到中型項目,強調速度和易用性。對於具有複雜需求和大量用戶的大型項目,Laravel的強大功能和可擴展性更為合適。而對於簡單專案或資源有限的情況下,CodeIgniter的輕量級和快速開發能力則較為理想。

Laravel和CodeIgniter:哪種框架比較適合小型專案? Laravel和CodeIgniter:哪種框架比較適合小型專案? Jun 04, 2024 pm 05:29 PM

對於小型項目,Laravel適用於大型項目,需要強大的功能和安全性。 CodeIgniter適用於非常小的項目,需要輕量級和易用性。

Laravel 和 CodeIgniter 的模板引擎哪一個比較好? Laravel 和 CodeIgniter 的模板引擎哪一個比較好? Jun 03, 2024 am 11:30 AM

比較了Laravel的Blade和CodeIgniter的Twig模板引擎,根據專案需求和個人偏好進行選擇:Blade基於MVC語法,鼓勵良好程式碼組織和模板繼承。 Twig是第三方函式庫,提供靈活語法、強大過濾器、擴充支援和安全沙箱。

CSDN 旗下 GitCode 被曝批量搬運 Github 項目,社區成員稱'內部在進行緊急整改” CSDN 旗下 GitCode 被曝批量搬運 Github 項目,社區成員稱'內部在進行緊急整改” Jun 28, 2024 am 03:11 AM

本站6月27日訊息,CSDN推出的開源代碼託管平台GitCode日前被批量搬運Github項目,甚至將原始項目中readme文件中的Github地址都替換為GitCode,還為開發者「貼心」註冊了同名帳號。在GitCode官方社區,昨日到今日有多條Issues要求立即刪除搬運項目和用戶,並得到了社區成員回應。對於開發者們的刪除要求,名為XXM的GitCode官方社群成員昨日在Issue中表達了歉意,並且直接表示按照要求刪除了專案和組織。然而,開發者發現還是能搜尋到該組織,質疑只是進行了暫時屏

See all articles