Rumah >pembangunan bahagian belakang >tutorial php >PHP dan OAuth: Melaksanakan penyepaduan log masuk LinkedIn

PHP dan OAuth: Melaksanakan penyepaduan log masuk LinkedIn

WBOY
WBOYasal
2023-07-28 16:28:501101semak imbas

PHP dan OAuth: Laksanakan integrasi log masuk LinkedIn

Dalam era media sosial hari ini, pengguna boleh mendaftar dan log masuk melalui pelbagai platform, yang sangat memudahkan proses pengurusan pengguna dan mendapatkan maklumat pengguna untuk pembangun laman web. OAuth ialah standard terbuka yang membolehkan pengguna membenarkan aplikasi pihak ketiga untuk mengakses sumber mereka pada platform tertentu tanpa memberikan nama pengguna dan kata laluan secara langsung. Dalam artikel ini, kita akan mempelajari cara melaksanakan penyepaduan log masuk LinkedIn menggunakan PHP dan OAuth.

LinkedIn ialah platform rangkaian profesional yang membolehkan pengguna membuat rangkaian dalam kalangan profesional dan berkongsi pengalaman kerja dan pencapaian mereka. Dengan menyepadukan log masuk LinkedIn, pembangun laman web boleh mendapatkan maklumat peribadi pengguna dengan lebih mudah dan memberikan pengalaman pengguna yang lebih tepat.

Langkah pertama ialah mencipta apl pada Platform Pembangun LinkedIn dan dapatkan kunci API dan kunci rahsia untuk apl tersebut. Log masuk ke platform pembangun, buat aplikasi dan ikut arahan untuk mengisi maklumat yang diperlukan. Selepas berjaya mencipta aplikasi, anda akan diberikan kunci API dan kunci rahsia, yang akan menjadi bukti kelayakan yang akan kami gunakan seterusnya.

Seterusnya, kita perlu menggunakan perpustakaan OAuth dalam PHP untuk melaksanakan proses kebenaran OAuth. Pertama, kita perlu memasang sambungan PHP OAuth yang diperlukan. Jalankan arahan berikut dalam baris arahan untuk memasang:

$ sudo apt-get install php-oauth

Selepas pemasangan berjaya, kita boleh mula menulis kod.

<?php

$api_key = 'YOUR_API_KEY';
$api_secret = 'YOUR_API_SECRET';
$callback_url = 'YOUR_CALLBACK_URL';

$oauth = new OAuth($api_key, $api_secret);
$oauth->setAuthType(OAUTH_AUTH_TYPE_URI);

$request_token = $oauth->getRequestToken('https://api.linkedin.com/uas/oauth/requestToken');
$request_token_info = $oauth->getLastResponseInfo();

if ($request_token_info['http_code'] == 200) {
  $request_token = explode('&', $request_token);
  $oauth_verifier = $request_token['oauth_verifier'];
  $oauth_token = $request_token['oauth_token'];
  
  $_SESSION['oauth_token'] = $oauth_token;
  $_SESSION['oauth_verifier'] = $oauth_verifier;
  
  header('Location: https://api.linkedin.com/uas/oauth/authorize?oauth_token='.$oauth_token);
  exit;
} else {
  // 处理错误
}

?>

Dalam kod di atas, kami mula-mula mentakrifkan kunci dan kunci API yang kami peroleh pada Platform Pembangun LinkedIn, serta URL panggil balik. Kemudian, kami menggunakan perpustakaan OAuth untuk mencipta objek OAuth dan menetapkan jenis keizinan kepada URI. Seterusnya, kami menggunakan kaedah getRequestToken untuk mendapatkan token permintaan dan mendapatkan maklumat respons. Jika mendapat token permintaan berjaya, kami menyimpan token dan pengesah daripada respons ke dalam sesi dan mengubah hala pengguna ke halaman kebenaran LinkedIn untuk mendapatkan kebenaran. getRequestToken方法获取一个请求令牌,并获取响应的信息。如果获取请求令牌成功,我们将响应中的令牌和验证器保存到会话中,并将用户重定向到LinkedIn授权页面进行授权。

完成授权后,LinkedIn将把用户重定向回我们的应用程序,并将验证器作为查询参数附加到回调URL中。我们可以在回调页面中获取验证器,并使用它来获取访问令牌。

<?php

$api_key = 'YOUR_API_KEY';
$api_secret = 'YOUR_API_SECRET';
$callback_url = 'YOUR_CALLBACK_URL';

$oauth_token = $_SESSION['oauth_token'];
$oauth_verifier = $_SESSION['oauth_verifier'];

$oauth = new OAuth($api_key, $api_secret);
$oauth->setAuthType(OAUTH_AUTH_TYPE_URI);
$oauth->setToken($oauth_token, $oauth_verifier);

$access_token = $oauth->getAccessToken('https://api.linkedin.com/uas/oauth/accessToken');
$access_token_info = $oauth->getLastResponseInfo();

if ($access_token_info['http_code'] == 200) {
  $access_token = explode('&', $access_token);
  $oauth_token = $access_token['oauth_token'];
  $oauth_token_secret = $access_token['oauth_token_secret'];
  
  // 使用访问令牌获取用户数据 
} else {
  // 处理错误
}

?>

在上述代码中,我们首先从会话中获取之前保存的令牌和验证器。然后,我们使用这些令牌和验证器创建一个OAuth对象,并设置授权类型为URI。接下来,我们使用getAccessToken

Setelah keizinan selesai, LinkedIn akan mengubah hala pengguna kembali ke aplikasi kami dan menambahkan pengesah sebagai parameter pertanyaan ke URL panggil balik. Kami boleh mendapatkan pengesah dalam halaman panggil balik dan menggunakannya untuk mendapatkan token akses.

<?php

$api_key = 'YOUR_API_KEY';
$api_secret = 'YOUR_API_SECRET';
$callback_url = 'YOUR_CALLBACK_URL';
$oauth_token = 'USER_ACCESS_TOKEN';
$oauth_token_secret = 'USER_ACCESS_TOKEN_SECRET';

$oauth = new OAuth($api_key, $api_secret);
$oauth->setAuthType(OAUTH_AUTH_TYPE_AUTHORIZATION);
$oauth->setToken($oauth_token, $oauth_token_secret);

$oauth->fetch('https://api.linkedin.com/v2/me');
$user_data = json_decode($oauth->getLastResponse());

// 处理用户数据

?>

Dalam kod di atas, kami mula-mula mendapat token dan pengesah yang disimpan sebelum ini daripada sesi. Kami kemudian mencipta objek OAuth menggunakan token dan pengesah ini dan menetapkan jenis kebenaran kepada URI. Seterusnya, kami menggunakan kaedah getAccessToken untuk mendapatkan token akses dan mendapatkan maklumat respons. Jika memperoleh token akses berjaya, kami menyimpan token dan kunci daripada respons ke dalam pembolehubah yang sesuai.

Langkah seterusnya ialah menggunakan token akses untuk mendapatkan data pengguna. Menurut dokumentasi API LinkedIn, kami boleh menggunakan token akses untuk mendapatkan profil asas pengguna, syarikat gabungan, jawatan dan maklumat lain.

Kod sampel adalah seperti berikut:

rrreee

Dalam kod di atas, kami mula-mula menentukan kunci API, kunci API, URL panggil balik dan token dan rahsia akses pengguna kami. Kemudian, kami mencipta objek OAuth dan menetapkan jenis keizinan kepada Kebenaran. Seterusnya, kami menggunakan token akses pengguna dan kunci rahsia untuk mendapatkan data pengguna. Dalam contoh ini, kami menggunakan API v2 LinkedIn untuk mendapatkan profil pengguna.

Selepas mendapatkan data pengguna, kami boleh memproses data mengikut keperluan. Anda boleh menyimpan data pengguna ke pangkalan data atau melakukan operasi lain berdasarkan logik perniagaan tertentu.

Melalui artikel ini, kami mempelajari cara melaksanakan penyepaduan log masuk LinkedIn menggunakan PHP dan OAuth. Melalui OAuth, kami boleh berkomunikasi dengan LinkedIn dengan selamat dan mendapatkan profil pengguna. Dengan cara ini, kami boleh memberikan pengguna pengalaman pengguna yang lebih diperibadikan dan tepat. 🎜🎜Saya harap artikel ini bermanfaat dan saya doakan anda berjaya dalam pembangunan anda! 🎜

Atas ialah kandungan terperinci PHP dan OAuth: Melaksanakan penyepaduan log masuk LinkedIn. 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

Artikel berkaitan

Lihat lagi