Rumah > pembangunan bahagian belakang > tutorial php > OAuth dalam PHP: Membina sistem CMS yang selamat

OAuth dalam PHP: Membina sistem CMS yang selamat

WBOY
Lepaskan: 2023-07-30 20:58:02
asal
786 orang telah melayarinya

OAuth dalam PHP: Membina sistem CMS yang selamat

    在现代的互联网应用中,用户的身份验证和授权是至关重要的。OAuth (开放授权) 是一种用于身份验证和授权的开放标准,它允许用户授权第三方应用访问其资源,而不需要直接提供用户名和密码。在本文中,我们将探讨如何使用PHP中的OAuth来构建一个安全的CMS系统,并提供一些具体的代码示例。
Salin selepas log masuk
  1. Kuasai konsep asas

Sebelum kita mula, marilah kita memahami beberapa konsep asas OAuth.

  • Pemilik Sumber: Pemilik sumber, biasanya pengguna.
  • Pelanggan: Aplikasi pihak ketiga yang ingin mengakses sumber pemilik sumber.
  • Pelayan Kebenaran: Bertanggungjawab untuk mengesahkan identiti pengguna dan mengeluarkan token akses.
  • Pelayan Sumber: Pelayan yang menyimpan sumber pengguna.
  1. Pasang perpustakaan OAuth

Terdapat banyak perpustakaan OAuth tersedia untuk PHP dan kami boleh menggunakannya untuk memudahkan pelaksanaan OAuth. Dalam artikel ini, kami akan menggunakan perpustakaan klien phpleague/oauth2.

Gunakan Komposer untuk pemasangan kebergantungan.

composer require league/oauth2-client
Salin selepas log masuk
  1. Pendaftaran hendaklah digunakan untuk mendapatkan ID dan kunci pelanggan

Sebelum menggunakan OAuth, kami perlu mendaftarkan apl kami pada pelayan kebenaran untuk mendapatkan ID dan kunci pelanggan. Langkah yang tepat berbeza-beza bergantung pada pembekal OAuth. Mengambil OAuth 2.0 sebagai contoh, kita boleh menggunakan GitHub sebagai pelayan kebenaran.

  1. Melaksanakan proses OAuth

Seterusnya, kami akan menggunakan contoh khusus untuk menunjukkan cara melaksanakan proses OAuth.

Mula-mula, buat fail index.php dan tambah kod berikut:

<?php

require_once 'vendor/autoload.php';

$provider = new LeagueOAuth2ClientProviderGithub([
    'clientId'          => 'YOUR_CLIENT_ID',
    'clientSecret'      => 'YOUR_CLIENT_SECRET',
    'redirectUri'       => 'http://localhost/callback.php',
]);

session_start();

if (!isset($_GET['code'])) {
    $authUrl = $provider->getAuthorizationUrl();
    $_SESSION['oauth2state'] = $provider->getState();
    header('Location: ' . $authUrl);
    exit;
} elseif (empty($_GET['state']) || ($_GET['state'] !== $_SESSION['oauth2state'])) {
    unset($_SESSION['oauth2state']);
    exit('Invalid state');
} else {
    $token = $provider->getAccessToken('authorization_code', [
        'code' => $_GET['code']
    ]);

    // 使用访问令牌进行API调用
    // ...
}
Salin selepas log masuk

Dalam kod di atas, kami mula-mula memperkenalkan kelas yang diperlukan dan menggunakan ID klien, kunci dan URL ubah hala yang kami dapat semasa mendaftar apl Mulakan penyedia GitHub .

Seterusnya, kami menggunakan kaedah getAuthorizationUrl untuk mendapatkan URL kebenaran dan menyimpan keadaan OAuth dalam sesi. getAuthorizationUrl方法获取授权URL,并将OAuth状态存储在会话中。

如果URL中没有code

Jika tiada parameter code dalam URL, kami mengubah hala pengguna ke URL kebenaran. Setelah pengguna berjaya dibenarkan, GitHub akan mengubah hala ke URL panggil balik yang kami sediakan.

Dalam skrip panggil balik callback.php, tambahkan kod berikut untuk melengkapkan aliran OAuth:

<?php

require_once 'vendor/autoload.php';

$provider = new LeagueOAuth2ClientProviderGithub([
    'clientId'          => 'YOUR_CLIENT_ID',
    'clientSecret'      => 'YOUR_CLIENT_SECRET',
    'redirectUri'       => 'http://localhost/callback.php',
]);

session_start();

if (!isset($_GET['code'])) {
    exit('Authorization code not found');
} else {
    try {
        $token = $provider->getAccessToken('authorization_code', [
            'code' => $_GET['code'],
        ]);
    } catch (LeagueOAuth2ClientProviderExceptionIdentityProviderException $e) {
        exit('Failed to obtain access token');
    }

    // 使用访问令牌进行API调用
    // ...
}
Salin selepas log masuk

Dalam skrip panggil balik, kami sekali lagi memulakan penyedia GitHub dengan ID pelanggan, rahsia dan URL ubah hala. Kami kemudian cuba mendapatkan token akses melalui kod kebenaran.
  1. Gunakan token akses untuk membuat panggilan API

Selepas mendapatkan token akses, kami boleh menggunakannya untuk membuat panggilan API dan mengakses sumber yang dilindungi pada pelayan sumber. Kaedah panggilan API khusus berbeza-beza bergantung pada keperluan sebenar dan pembekal OAuth.

<?php

// 使用访问令牌进行API调用
$response = $provider->getAuthenticatedRequest(
    'GET',
    'https://api.github.com/user',
    $token
);

$httpClient = $provider->getHttpClient();
$user = json_decode($httpClient->send($response)->getBody(), true);

echo 'Hello, ' . $user['login'];
Salin selepas log masuk
Dalam contoh di atas, kami menggunakan token akses untuk mendapatkan maklumat pengguna semasa melalui permintaan GET dan memaparkan keputusan pada halaman.
  1. Ringkasan

Melalui contoh dalam artikel ini, kami mempelajari cara menggunakan OAuth dalam PHP untuk membina sistem CMS yang selamat. Kami mula-mula memasang pustaka OAuth melalui Komposer, kemudian mendaftarkan apl dan mendapatkan ID klien dan rahsia. Seterusnya, kami memperoleh token akses melalui aliran OAuth dan menggunakannya untuk membuat panggilan API. Akhir sekali, kami boleh melakukan pemprosesan kebenaran dan pengesahan yang sesuai mengikut keperluan sebenar.

Menggunakan OAuth boleh melindungi privasi dan keselamatan pengguna dengan berkesan serta menyediakan mekanisme kawalan akses yang mudah. Ia memainkan peranan penting dalam aplikasi seperti membina sistem CMS yang selamat.

Pautan rujukan:
  • https://oauth.net/
  • https://github.com/thephpleague/oauth2-client
🎜

Atas ialah kandungan terperinci OAuth dalam PHP: Membina sistem CMS yang selamat. 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