Rumah >pembangunan bahagian belakang >tutorial php >Mudah masukkan log masuk sosial ke aplikasi anda dengan sosialit

Mudah masukkan log masuk sosial ke aplikasi anda dengan sosialit

Christopher Nolan
Christopher Nolanasal
2025-02-10 16:22:13504semak imbas

Laravel Socialite: Menyelaraskan pengesahan sosial dalam aplikasi Laravel

Artikel ini, peer-reviewed oleh Wern Ancheta dan pengulas SitePoint yang lain, meneroka Socialite Laravel, pakej yang memudahkan pengesahan sosial.

Easily Add Social Logins to Your App with Socialite

Socialite secara langsung menyokong Google, Facebook, Twitter, LinkedIn, GitHub, dan Bitbucket. Walaupun tiada lagi penyedia rasmi yang dirancang, projek penyedia sosialit yang didorong oleh komuniti menawarkan banyak sambungan tidak rasmi.

Tutorial ini menganggap aplikasi Laravel yang berfungsi. Homestead bertambah baik dicadangkan untuk persekitaran pembangunan yang mantap.

Konsep Utama:

    Socialite Abstrak Pengesahan log masuk sosial yang kompleks.
  • Ia menyokong penyedia oauth utama, dengan sambungan yang disediakan oleh masyarakat.
  • Konfigurasi melibatkan mendaftarkan aplikasi anda di setiap platform sosial untuk mendapatkan kelayakan dan mengemas kini
  • . config/services.php
  • pelarasan skema pangkalan data (mis., Membuat e -mel dan kata laluan tidak dapat dipertahankan) diperlukan.
  • Penyedia tersuai memperluaskan fungsi sosialit untuk platform yang tidak disokong.
  • Tutorial menunjukkan log masuk sosial GitHub, termasuk panggilan balik OAuth dan kemas kini pengesahan pengguna.

Pengesahan berasaskan borang standard:

Sebelum mengintegrasikan log masuk sosial, sediakan pengesahan berasaskan borang lalai Laravel:

<code class="language-bash">php artisan make:auth
php artisan migrate</code>
menavigasi ke

harus memaparkan halaman log masuk berfungsi. /login

Easily Add Social Logins to Your App with Socialite

Menambah Pengesahan Sosial dengan Socialite:

Pasang Socialite Menggunakan Komposer:

Daftar penyedia perkhidmatan dan fasad dalam
<code class="language-bash">composer require laravel/socialite</code>
:

config/app.php

Socialite adalah perkhidmatan singleton yang dimuatkan malas.
<code class="language-php">'providers' => [
    // ...
    Laravel\Socialite\SocialiteServiceProvider::class,
],

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

Konfigurasi:

Daftar aplikasi OAuth pada setiap platform yang dikehendaki untuk mendapatkan ID pelanggan dan kunci rahsia. Tambahkan kelayakan ini ke

:

config/services.php

Simpan nilai kunci sebenar dalam fail
<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>
anda.

.env

Pengubahsuaian pangkalan data:

Untuk menampung log masuk sosial, ubah suai skema Jadual

untuk membolehkan medan e -mel dan kata laluan yang tidak dapat dibatalkan. Pasang

: users doctrine/dbal

Buat penghijrahan:
<code class="language-bash">composer require doctrine/dbal</code>

3

Buat model dan penghijrahan untuk akaun sosial yang dipautkan (): Penghijrahan ini harus termasuk
<code class="language-bash">php artisan make:migration prepare_users_table_for_social_authentication --table users</code>
,

, dan unik database/migrations/.... Jalankan email. password

Model:

Tentukan hubungan satu-ke-banyak antara User dan LinkedSocialAccount dalam kedua-dua model. Buat provider_name dan provider_id massa yang boleh ditugaskan dalam LinkedSocialAccount.

Pengawal:

Buat SocialAccountController dengan redirectToProvider dan handleProviderCallback kaedah. redirectToProvider mengalihkan kepada pembekal OAuth. handleProviderCallback mengendalikan panggilan balik, menggunakan kelas penolong SocialAccountsService untuk mencari atau membuat pengguna dan menghubungkan akaun sosial.

SocialAccountSservice Helper Class:

Kaedah findOrCreate kelas ini cek untuk akaun berkaitan yang ada atau membuat pengguna dan pautan baru.

Laluan:

Tambahkan laluan untuk pengalihan log masuk sosial dan panggilan balik dalam routes/web.php:

<code class="language-bash">php artisan make:auth
php artisan migrate</code>

GitHub Login Contoh:

Daftar permohonan OAuth GitHub, dapatkan kelayakan, dan tambahkannya ke

dan config/services.php. Tambahkan pautan log masuk github ke paparan log masuk anda. .env

Easily Add Social Logins to Your App with Socialite Easily Add Social Logins to Your App with Socialite Easily Add Social Logins to Your App with Socialite

Projek Penyedia Sosial:

Projek Penyedia Sosialit menawarkan banyak penyedia tidak rasmi. Gantikan penyedia perkhidmatan sosialit Laravel dengan penyedia perkhidmatan penyedia sosialit di

. Daftar setiap pendengar acara pembekal di config/app.php. app/Providers/EventServiceProvider.php

Spotify Login Contoh:

Pasang pembekal Spotify menggunakan komposer, daftar aplikasi pada platform pemaju Spotify, tambahkan kelayakan ke

, dan tambahkan pautan Login Spotify ke pandangan anda. .env

Easily Add Social Logins to Your App with Socialite Easily Add Social Logins to Your App with Socialite

Mencipta pembekal tersuai:

Buat kelas penyedia yang memanjangkan

dan pendengar acara untuk mendaftarkannya. Rujuk contoh penyedia deezer dalam artikel asal untuk panduan. LaravelSocialiteTwoAbstractProvider

Kod Lengkap boleh didapati di GitHub. Artikel ini disimpulkan dengan Soalan Lazim yang meliputi pemasangan, konfigurasi, pengendalian ralat, keselamatan, dan ujian.

Atas ialah kandungan terperinci Mudah masukkan log masuk sosial ke aplikasi anda dengan sosialit. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn