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.
Tutorial ini menganggap aplikasi Laravel yang berfungsi. Homestead bertambah baik dicadangkan untuk persekitaran pembangunan yang mantap.
Konsep Utama:
config/services.php
Pengesahan berasaskan borang standard:
Sebelum mengintegrasikan log masuk sosial, sediakan pengesahan berasaskan borang lalai Laravel:
php artisan make:auth php artisan migrate
harus memaparkan halaman log masuk berfungsi. /login
Pasang Socialite Menggunakan Komposer:
Daftar penyedia perkhidmatan dan fasad dalam
composer require laravel/socialite
config/app.php
'providers' => [ // ... Laravel\Socialite\SocialiteServiceProvider::class, ], 'aliases' => [ // ... 'Socialite' => Laravel\Socialite\Facades\Socialite::class, ],
Konfigurasi:
Daftar aplikasi OAuth pada setiap platform yang dikehendaki untuk mendapatkan ID pelanggan dan kunci rahsia. Tambahkan kelayakan ini ke
:
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
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
composer require doctrine/dbal
3
Buat model dan penghijrahan untuk akaun sosial yang dipautkan (php artisan make:migration prepare_users_table_for_social_authentication --table users
, 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
:
php artisan make:auth php artisan migrate
GitHub Login Contoh:
dan config/services.php
. Tambahkan pautan log masuk github ke paparan log masuk anda. .env
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
Mencipta pembekal tersuai:
Buat kelas penyedia yang memanjangkan dan pendengar acara untuk mendaftarkannya. Rujuk contoh penyedia deezer dalam artikel asal untuk panduan. LaravelSocialiteTwoAbstractProvider
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!