ホームページ >バックエンド開発 >PHPチュートリアル >ソーシャルログインをソーシャルライトで簡単に追加してください

ソーシャルログインをソーシャルライトで簡単に追加してください

Christopher Nolan
Christopher Nolanオリジナル
2025-02-10 16:22:13466ブラウズ

laravel socialite:laravelアプリケーションでのソーシャル認証の合理化

この記事は、Wern Anchetaやその他のSitePoint Reviewersによって査読され、Laravel SocialIte、Packageを簡素化するソーシャル認証を探ります。

Easily Add Social Logins to Your App with Socialite

Socialiteは、Google、Facebook、Twitter、LinkedIn、Github、およびBitbucketを直接サポートしています。 これ以上の公式プロバイダーは計画されていませんが、コミュニティ主導のソーシャルプロバイダープロジェクトは、多くの非公式の拡張機能を提供しています。 このチュートリアルは、動作するLaravelアプリケーションを想定しています。 堅牢な開発環境には、Homesteadの改善が提案されています

重要な概念:

Laravel SocialIte Abstractsは、複雑なソーシャルログイン認証を抽象化しています コミュニティが提供する拡張機能を備えた主要なOAuthプロバイダーをサポートしています 構成には、各ソーシャルプラットフォームにアプリを登録して資格情報を取得し、

  • データベーススキーマの調整(たとえば、電子メールとパスワードをターゲットにする)が必要です。
  • カスタムプロバイダーは、サポートされていないプラットフォームに対してSocialIteの機能を拡張します
  • チュートリアルでは、OAUTHコールバックやユーザー認証の更新など、GitHubソーシャルログインを示しています。
  • config/services.php
  • 標準のフォームベースの認証:
  • に移動すると、機能ログインページが表示されます

ソーシャル認証をソーシャルに追加する:

<code class="language-bash">php artisan make:auth
php artisan migrate</code>
コンポーザーを使用してソーシャルをインストールします:

/login

サービスプロバイダーとファサードを

Easily Add Social Logins to Your App with Socialite に登録します

socialiteは、怠zyな荷積みのシングルトンサービスです。

構成:

<code class="language-bash">composer require laravel/socialite</code>
クライアントIDとシークレットキーを取得するために、希望する各プラットフォームにOAuthアプリケーションを登録します。 これらの資格情報を

config/app.phpに追加します

<code class="language-php">'providers' => [
    // ...
    Laravel\Socialite\SocialiteServiceProvider::class,
],

'aliases' => [
    // ...
    'Socialite' => Laravel\Socialite\Facades\Socialite::class,
],</code>

ファイルに実際のキー値を保存します。

データベースの変更:

ソーシャルログインに対応するには、

テーブルスキーマを変更して、ヌル可能な電子メールとパスワードフィールドを許可します。 config/services.php

をインストールします
<code class="language-php">'facebook' => [
    'client_id'     => env('FB_CLIENT_ID'),
    'client_secret' => env('FB_CLIENT_SECRET'),
    'redirect'      => env('FB_URL'),
],
// ...similar entries for other providers...</code>

移行を作成:.env

移行ファイル()を更新して、

をnullableにします。

usersリンクされたソーシャルアカウントのモデルと移行を作成します():この移行には、doctrine/dbal

、および一意の
<code class="language-bash">composer require doctrine/dbal</code>
を含める必要があります。 実行

モデル:

両方のモデルで、

Userの間の1対多数の関係を定義します。 LinkedSocialAccount provider_nameprovider_idコントローラー:LinkedSocialAccount

およびメソッドを使用して

を作成します。

OAuthプロバイダーにリダイレクトします。 SocialAccountControllerヘルパークラスを使用してユーザーを見つけたり作成したり、ソーシャルアカウントをリンクしたりして、コールバックを処理します。 redirectToProviderhandleProviderCallbackSocialAccountSService Helperクラス:redirectToProviderhandleProviderCallback SocialAccountsServiceこのクラスの

メソッドは、既存のリンクされたアカウントをチェックするか、新しいユーザーとリンクを作成します。

ルート:

ソーシャルログインのリダイレクトとコールバック用のルートをfindOrCreate

githubログイン例:

routes/web.phpgithub oauthアプリケーションを登録し、資格情報を取得し、それらを

および
<code class="language-bash">php artisan make:auth
php artisan migrate</code>
に追加します。 githubログインリンクをログインビューに追加します。

config/services.php .env

ソーシャル人プロバイダープロジェクト:

Easily Add Social Logins to Your App with Socialite Easily Add Social Logins to Your App with Socialite ソーシャル人プロバイダープロジェクトは、多くの非公式プロバイダーを提供しています。 LaravelのSocialIte Service ProviderをEasily Add Social Logins to Your App with Socialite の社交プロバイダーのサービスプロバイダーに置き換えます。 各プロバイダーのイベントリスナーを

に登録します spotifyログイン例:

config/app.phpComposerを使用してSpotifyプロバイダーをインストールし、Spotifyの開発者プラットフォームにアプリを登録し、資格情報をapp/Providers/EventServiceProvider.phpに追加し、Spotifyログインリンクをビューに追加します。

カスタムプロバイダーの作成:.env

プロバイダークラスを作成し、Easily Add Social Logins to Your App with Socialite を拡張し、イベントリスナーを登録します。 ガイダンスについては、元の記事のDeezerプロバイダーの例を参照してください。 Easily Add Social Logins to Your App with Socialite 完全なコードはGitHubで利用できます。 この記事は、インストール、構成、エラー処理、セキュリティ、およびテストをカバーするFAQで締めくくります。

以上がソーシャルログインをソーシャルライトで簡単に追加してくださいの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。