Rumah > rangka kerja php > Laravel > Cara menggunakan Laravel untuk melaksanakan fungsi log masuk pihak ketiga

Cara menggunakan Laravel untuk melaksanakan fungsi log masuk pihak ketiga

王林
Lepaskan: 2023-11-02 11:01:11
asal
1353 orang telah melayarinya

Cara menggunakan Laravel untuk melaksanakan fungsi log masuk pihak ketiga

Dalam beberapa tahun kebelakangan ini, dengan perkembangan berterusan teknologi Internet, orang ramai mempunyai keperluan yang lebih tinggi dan lebih tinggi untuk keselamatan dan pengalaman pengguna tapak web atau aplikasi. Untuk memudahkan pendaftaran dan log masuk pengguna, log masuk akaun pihak ketiga telah menjadi salah satu fungsi yang biasa digunakan dalam laman web dan aplikasi. Sebagai rangka kerja PHP yang popular, Laravel menyediakan fungsi kebenaran log masuk sosial yang mudah, menjadikannya sangat mudah untuk melaksanakan fungsi log masuk pihak ketiga. Artikel ini akan memperkenalkan cara menggunakan Laravel untuk melaksanakan fungsi log masuk pihak ketiga dan menyediakan beberapa kod pelaksanaan untuk rujukan pembaca.

1. Konfigurasikan maklumat pembekal perkhidmatan

Dalam Laravel, kami boleh menggunakan pakej kebenaran log masuk sosial socialite untuk melaksanakan fungsi log masuk pihak ketiga. socialite menyokong pelbagai penyedia perkhidmatan yang dibenarkan, termasuk Facebook, Google, Twitter, WeChat, dsb. Oleh itu, sebelum menggunakan socialite untuk melaksanakan fungsi log masuk pihak ketiga, kami perlu mengkonfigurasi maklumat pembekal perkhidmatan. socialite来实现第三方登录功能。而socialite支持的授权服务提供商多种多样,包括Facebook、Google、Twitter、WeChat等。因此,在使用socialite实现第三方登录功能之前,我们需要配置服务商信息。

以GitHub为例,通过创建并授权一个OAuth应用程序,我们可以获取到客户端ID和客户端密钥两个信息。具体的获取方式如下:

  1. 访问GitHub的网站,并登录账户。
  2. 进入GitHub的设置页面,选择"Developer settings"选项卡,点击"OAuth Apps",然后选择"New OAuth App"。
  3. 填写应用程序的详细信息,包括应用名称、应用主页URL、授权回调URL等。
  4. 提交并创建应用程序。创建成功后,可以在GitHub页面中找到该应用程序的客户端ID和客户端密钥等信息。

有了这些信息之后,我们就可以创建一个名为/config/services.php的Laravel配置文件,并在其中添加以下内容:

'github' => [
    'client_id' => env('GITHUB_CLIENT_ID'),
    'client_secret' => env('GITHUB_CLIENT_SECRET'),
    'redirect' => 'http://localhost:8000/login/github/callback',
],
Salin selepas log masuk

其中,github是我们要使用的服务提供商的名称,client_idclient_secret是我们在申请OAuth应用程序时获取到的客户端ID和客户端密钥,redirect是OAuth回调URL,它是我们在创建应用程序时填写的授权回调URL。这里我们设置为localhost:8000/login/github/callback,后面我们将会在路由文件中创建这个路由。

二、创建路由

接下来,我们需要在Laravel应用程序的路由文件中创建路由,实现通过GitHub登录的功能。在这里,我们可以使用Laravel的Route类来创建路由。

第一步,我们需要创建一个授权跳转路由,由它负责将用户跳转至GitHub登录页面。在路由文件中添加以下代码:

Route::get('login/github', function () {
    return Socialite::driver('github')->redirect();
});
Salin selepas log masuk

其中,Socialite::driver('github')调用socialite授权包的driver方法,获取到GitHub服务提供商的实例。而redirect方法则实现了OAuth授权跳转,将用户重定向到GitHub的认证授权页面上。

第二步,我们创建一个授权回调路由,由它负责获取GitHub服务提供商返回的用户信息,并进行处理。在路由文件中添加以下代码:

Route::get('login/github/callback', function () {
    $user = Socialite::driver('github')->user();
    // 处理用户信息
});
Salin selepas log masuk

其中,Socialite::driver('github')调用socialite授权包的driver方法,获取到GitHub服务提供商的实例。而user方法则实现了OAuth授权获取用户信息的过程,它会从GitHub服务提供商获取到用户的信息,该信息将以$user变量形式被返回。

在获取到$user变量之后,我们便可以对用户信息进行处理了。由于每个第三方服务提供商返回的用户信息格式略有不同,因此这里就不做详细展开了。

三、创建公用方法

为了方便管理和使用,我们可以在app/Http/Controllers/Auth/LoginController.php控制器中创建GitHub方法,供其他方法调用。

在该方法中,我们首先需要使用Socialite::driver('github')->redirect()方法将用户重定向到GitHub登录页面上。而在获取用户信息的回调过程中,我们可以在GitHubCallback方法中对用户信息进行处理。

下面是一个基本的示例代码:

<?php
namespace AppHttpControllersAuth;

use AppHttpControllersController;
use Socialite;

class LoginController extends Controller
{
    /**
     * 重定向到GitHub登录页面
     *
     * @return Response
     */
    public function GitHub()
    {
        return Socialite::driver('github')->redirect();
    }

    /**
     * 从GitHub获取用户信息
     *
     * @return Response
     */
    public function GitHubCallback()
    {
        $user = Socialite::driver('github')->user();
        dd($user);
    }
}
Salin selepas log masuk

四、使用扩展包

如果你觉得上述方法过程繁琐,可以使用社交化登录授权扩展包laravel/socialite,这个扩展包已经对各大服务提供商进行了封装,并提供了相对应的命令行工具来构造授权服务提供商。

  1. 安装laravel/socialite

在终端中使用composer安装laravel/socialite扩展包:

composer require laravel/socialite
Salin selepas log masuk
  1. 配置服务商信息

在Laravel的配置文件config/services.php中,添加需要使用的服务商信息,下面以GitHub为例:

'github' => [
    'client_id' => env('GITHUB_CLIENT_ID'),
    'client_secret' => env('GITHUB_CLIENT_SECRET'),
    'redirect' => '/auth/github/callback',
],
Salin selepas log masuk
  1. 创建授权路由

routes/web.php

Mengambil GitHub sebagai contoh, dengan mencipta dan membenarkan aplikasi OAuth, kami boleh mendapatkan ID klien dan kunci klien. Kaedah pemerolehan khusus adalah seperti berikut: #🎜🎜#
  1. Lawati tapak web GitHub dan log masuk ke akaun.
  2. Masukkan halaman tetapan GitHub, pilih tab "Tetapan pembangun", klik "Apl OAuth", dan kemudian pilih "Apl OAuth Baharu".
  3. Isi maklumat terperinci aplikasi, termasuk nama aplikasi, URL halaman utama aplikasi, URL panggil balik kebenaran, dsb.
  4. Serahkan dan buat aplikasi. Selepas penciptaan berjaya, maklumat seperti ID klien dan kunci klien aplikasi boleh didapati di halaman GitHub.
#🎜🎜#Dengan maklumat ini, kami boleh mencipta fail konfigurasi Laravel bernama /config/services.php dan menambah kandungan berikut padanya: #🎜🎜#
Route::get('/auth/github', 'AuthLoginController@GitHub');
Salin selepas log masuk
Salin selepas log masuk
#🎜🎜#Antaranya, github ialah nama pembekal perkhidmatan yang ingin kami gunakan, client_id dan client_secret ialah nama yang kami gunakan The ID klien dan kunci klien yang diperoleh semasa memohon aplikasi OAuth redirect ialah URL panggil balik OAuth, iaitu URL panggil balik kebenaran yang kami isi semasa membuat aplikasi. Di sini kami menetapkannya kepada localhost:8000/login/github/callback Kami akan mencipta laluan ini dalam fail penghalaan kemudian. #🎜🎜##🎜🎜# 2. Buat laluan #🎜🎜##🎜🎜# Seterusnya, kita perlu mencipta laluan dalam fail penghalaan aplikasi Laravel untuk melaksanakan fungsi log masuk melalui GitHub. Di sini, kita boleh menggunakan kelas Route Laravel untuk mencipta laluan. #🎜🎜##🎜🎜#Langkah pertama ialah membuat laluan ubah hala keizinan, yang bertanggungjawab untuk mengubah hala pengguna ke halaman log masuk GitHub. Tambah kod berikut dalam fail penghalaan: #🎜🎜#
Route::get('/auth/github/callback', 'AuthLoginController@GitHubCallback');
Salin selepas log masuk
Salin selepas log masuk
#🎜🎜#Antaranya, Socialite::driver('github') memanggil <code>socialite</ kod> kaedah pemandu pakej kebenaran untuk mendapatkan contoh pembekal perkhidmatan GitHub. Kaedah redirect melaksanakan lompatan kebenaran OAuth dan mengubah hala pengguna ke halaman pengesahan dan kebenaran GitHub. #🎜🎜##🎜🎜# Dalam langkah kedua, kami mencipta laluan panggil balik kebenaran, yang bertanggungjawab untuk mendapatkan maklumat pengguna yang dikembalikan oleh penyedia perkhidmatan GitHub dan memprosesnya. Tambah kod berikut dalam fail penghalaan: #🎜🎜#
use Socialite;

class LoginController extends Controller
{

    public function GitHub()
    {
        return Socialite::driver('github')->redirect();
    }

    public function GitHubCallback()
    {
        $user = Socialite::driver('github')->user();
        dd($user);
    }

}
Salin selepas log masuk
Salin selepas log masuk
#🎜🎜#Antaranya, Socialite::driver('github') memanggil <code>socialite</ kod> kaedah pemandu pakej kebenaran untuk mendapatkan contoh pembekal perkhidmatan GitHub. Kaedah user melaksanakan proses mendapatkan maklumat pengguna melalui kebenaran OAuth Ia akan mendapatkan maklumat pengguna daripada pembekal perkhidmatan GitHub, yang akan disimpan dalam bentuk $user</code. > pembolehubah. #🎜🎜##🎜🎜#Selepas memperoleh pembolehubah <code>$user, kami boleh memproses maklumat pengguna. Memandangkan format maklumat pengguna yang dikembalikan oleh setiap pembekal perkhidmatan pihak ketiga adalah berbeza sedikit, kami tidak akan membincangkan butiran di sini. #🎜🎜##🎜🎜#3 Cipta kaedah awam #🎜🎜##🎜🎜#Untuk memudahkan pengurusan dan penggunaan, kami boleh menggunakan app/Http/Controllers/Auth/LoginController.php</code. > pengawal Cipta kaedah <code>GitHub untuk kaedah lain memanggil. #🎜🎜##🎜🎜#Dalam kaedah ini, kita perlu menggunakan kaedah Socialite::driver('github')->redirect() untuk mengubah hala pengguna ke halaman log masuk GitHub . Semasa proses panggil balik untuk mendapatkan maklumat pengguna, kami boleh memproses maklumat pengguna dalam kaedah GitHubCallback. #🎜🎜##🎜🎜#Berikut ialah kod sampel asas: #🎜🎜#rrreee#🎜🎜# 4. Gunakan pek pengembangan #🎜🎜##🎜🎜# Jika anda rasa kaedah di atas menyusahkan, anda boleh gunakan sosialisasi Pakej sambungan kebenaran log masuk laravel/socialite, pakej sambungan ini telah merangkumi pembekal perkhidmatan utama dan menyediakan alatan baris arahan yang sepadan untuk membina pembekal perkhidmatan yang dibenarkan. #🎜🎜#
  1. Pasang laravel/socialite
#🎜🎜#Gunakan komposer dalam terminal untuk memasang laravel/socialite</code > Pakej sambungan: #🎜🎜#rrreee<ol start="2"><li>Konfigurasikan maklumat pembekal perkhidmatan</li></ol>#🎜🎜#Dalam fail konfigurasi Laravel <code>config/services.php</ kod < Dalam kod>laluan/web.phpfail penghalaan, buat laluan kebenaran yang tidak disahkan: #🎜🎜#
Route::get('/auth/github', 'AuthLoginController@GitHub');
Salin selepas log masuk
Salin selepas log masuk
  1. 创建回调路由

routes/web.php路由文件中,创建一个授权回调路由:

Route::get('/auth/github/callback', 'AuthLoginController@GitHubCallback');
Salin selepas log masuk
Salin selepas log masuk
  1. 创建控制器

app/Http/Controllers/Auth目录下,创建一个名为LoginController.php的控制器。控制器中添加方法GitHubGitHubCallback实现授权和回调过程,具体代码如下:

use Socialite;

class LoginController extends Controller
{

    public function GitHub()
    {
        return Socialite::driver('github')->redirect();
    }

    public function GitHubCallback()
    {
        $user = Socialite::driver('github')->user();
        dd($user);
    }

}
Salin selepas log masuk
Salin selepas log masuk

至此,我们已经成功使用laravel/socialite扩展包实现了第三方登录的功能。

总结:

本文介绍了如何使用Laravel框架的社交化登录授权包socialite,在实现第三方登录功能方面变得尤为便利。通过配置服务商信息、创建路由以及使用扩展包等方法,我们可以轻松地实现通过GitHub登录的功能。希望这篇文章能够对各位开发人员有所帮助。

Atas ialah kandungan terperinci Cara menggunakan Laravel untuk melaksanakan fungsi log masuk pihak ketiga. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan