laravel colecition:簡化Laravel應用程序中的社會身份驗證
本文,由Wern Ancheta和其他SitePoint審稿人進行的同行評審,探索Laravel Socialite,簡化社交認證的軟件包。
Socialite直接支持Google,Facebook,Twitter,LinkedIn,Github和Bitbucket。 儘管沒有計劃進一步的官方提供者,但社區驅動的社交名流提供商項目提供了許多非官方的擴展。
本教程假設了一個有效的Laravel應用程序。 建議改進宅基地,以實現強大的開發環境。
密鑰概念:
config/services.php
>數據庫架構調整(例如,通過發送電子郵件和密碼無效)是必要的。 > >在整合社交登錄之前,請設置Laravel的基於默認表格的身份驗證:
導航到
php artisan make:auth php artisan migrate
>
/login
使用作曲家安裝社交名稱:
註冊服務提供商和
composer require laravel/socialite
config/app.php
'providers' => [ // ... Laravel\Socialite\SocialiteServiceProvider::class, ], 'aliases' => [ // ... 'Socialite' => Laravel\Socialite\Facades\Socialite::class, ],
> configuration:
>在每個所需平台上註冊一個OAUTH應用程序,以獲取客戶端ID和秘密密鑰。 將這些憑據添加到>:
>
config/services.php
>將實際鍵值存儲在您的
'facebook' => [ 'client_id' => env('FB_CLIENT_ID'), 'client_secret' => env('FB_CLIENT_SECRET'), 'redirect' => env('FB_URL'), ], // ...similar entries for other providers...
.env
數據庫修改:
要容納社交登錄,請修改
users
創建一個遷移:doctrine/dbal
composer require doctrine/dbal
)以使
和php artisan make:migration prepare_users_table_for_social_authentication --table users
nullable。
database/migrations/...
>為鏈接的社交帳戶創建模型和遷移:此遷移應包括email
>,password
和一個唯一的
。 LinkedSocialAccount
模型:
在兩個模型中定義User
>中進行LinkedSocialAccount
和provider_name
質量分配
provider_id
LinkedSocialAccount
控制器:
> 用和
方法創建。 SocialAccountController
重定向到OAuth提供商。 redirectToProvider
>處理回調,使用A handleProviderCallback
助手類查找或創建用戶並鏈接社交帳戶。 redirectToProvider
handleProviderCallback
SocialAccountsService
socialAccountsService助手類:
此類的>檢查現有鏈接帳戶或創建新用戶和鏈接的方法。
路由:findOrCreate
添加社交登錄的路線,以重定向和回調:>
routes/web.php
> github登錄示例:
php artisan make:auth php artisan migrate
註冊一個GitHub Oauth應用程序,獲取憑據,然後將其添加到
config/services.php
.env
>社交名流提供者項目:
>社交名流提供者項目為許多非正式提供者提供。 用社交名流提供商的服務提供商替換Laravel的社交名流服務提供商。 註冊每個提供商的事件偵聽器,
。
> Spotify登錄示例:
>,然後將Spotify登錄鏈接添加到您的視圖中。
config/app.php
app/Providers/EventServiceProvider.php
創建自定義提供者:
>創建一個提供者類擴展.env
和一個事件偵聽器進行註冊。 請參閱原始文章中的Deezer提供商示例。
以上是通過社交名錄輕鬆地在您的應用中添加社交登錄的詳細內容。更多資訊請關注PHP中文網其他相關文章!