Maison >développement back-end >tutoriel php >L'intégration PHP et OAuth implémente une autorisation d'accès aux API tierces

L'intégration PHP et OAuth implémente une autorisation d'accès aux API tierces

WBOY
WBOYoriginal
2023-06-25 12:21:261722parcourir

Avec le développement continu de la technologie Internet, de nombreux produits doivent faire appel à des interfaces API tierces pour réaliser une expansion fonctionnelle. Parmi eux, OAuth est un cadre d'autorisation standard largement utilisé. Son objectif est de fournir un mécanisme d'autorisation entre différentes applications afin que les utilisateurs puissent autoriser des applications tierces à accéder à leurs ressources sans révéler leur nom d'utilisateur et leur mot de passe à des tiers. Cet article expliquera comment utiliser PHP pour intégrer le framework OAuth afin de mettre en œuvre une autorisation d'accès aux API tierces.

1. Le concept de base d'OAuth

OAuth est un cadre d'autorisation standard ouvert. Son objectif est de fournir un mécanisme d'autorisation entre différentes applications afin que les utilisateurs puissent autoriser des applications tierces à accéder à leurs ressources sans divulguer leur nom d'utilisateur et leur mot de passe à des tiers. fêtes.

Dans le framework OAuth, il y a trois rôles : Serveur d'autorisation, Serveur de ressources et Client. Parmi eux, le serveur d'autorisation est responsable de l'authentification et de l'autorisation des utilisateurs, le serveur de ressources est responsable du stockage et de la fourniture des ressources, et le client est une application qui doit accéder aux ressources.

Le processus d'autorisation OAuth comprend généralement les étapes suivantes :

  1. Inscription du client : le client s'inscrit auprès du serveur d'autorisation et demande un identifiant client et une clé secrète client.
  2. Demande d'autorisation : le client demande l'autorisation de l'utilisateur au serveur d'autorisation, et le serveur d'autorisation redirige l'utilisateur vers la page de connexion et demande à l'utilisateur de saisir un nom d'utilisateur et un mot de passe.
  3. Autorisation utilisateur : une fois que l'utilisateur a saisi son nom d'utilisateur et son mot de passe, le serveur d'autorisation vérifie l'identité de l'utilisateur et demande à l'utilisateur d'approuver la demande du client pour accéder à ses ressources.
  4. Obtenir l'autorisation : le serveur d'autorisation émet un jeton d'accès et un jeton d'actualisation au client.
  5. Accès aux ressources : le client utilise le jeton d'accès pour accéder au serveur de ressources afin d'obtenir les données utilisateur.
  6. Jeton d'actualisation : lorsque le jeton d'accès expire, le client utilise le jeton d'actualisation pour demander un nouveau jeton d'accès au serveur d'autorisation.

2. Intégration de PHP et OAuth

PHP fournit de nombreuses bibliothèques de classes et frameworks pour implémenter facilement l'autorisation OAuth. Ce qui suit prend oauth2-client comme exemple pour présenter comment utiliser PHP pour intégrer le framework OAuth afin d'implémenter l'autorisation d'accès aux API tierces.

  1. Installer oauth2-client

oauth2-client est un client OAuth2.0 implémenté en PHP, qui peut être utilisé pour demander des jetons d'accès au serveur d'autorisation OAuth2.0. L'installation de oauth2-client peut être effectuée via composer. Exécutez la commande suivante dans le terminal pour installer oauth2-client :

$ composer require league/oauth2-client
  1. Créer un client

Avant d'utiliser oauth2-client, vous devez créer un objet client. L'objet client contient les informations de configuration suivantes :

<?php
$provider = new LeagueOAuth2ClientProviderGenericProvider([
    'clientId'                => '...',
    'clientSecret'            => '...',
    'redirectUri'             => '...',
    'urlAuthorize'            => '...',
    'urlAccessToken'          => '...',
    'urlResourceOwnerDetails' => '...'
]);
?>

Ici, clientId, clientSecret et redirectUri sont requis, et d'autres liens URL doivent être renseignés en fonction de la situation réelle.

  1. Demande de code d'autorisation

Ensuite, nous devons demander un code d'autorisation. Dans le processus d'autorisation OAuth2.0, le client doit d'abord obtenir le code d'autorisation, puis utiliser le code d'autorisation pour demander un jeton d'accès au serveur d'autorisation.

<?php
$authUrl = $provider->getAuthorizationUrl();
header('Location: '.$authUrl);

Dans le code ci-dessus, nous obtenons le lien de demande de code d'autorisation via la méthode getAuthorizationUrl et utilisons la fonction d'en-tête pour rediriger l'utilisateur vers le lien d'autorisation, en attendant l'autorisation de l'utilisateur.

  1. Obtenir le jeton d'accès

Après une autorisation réussie, le serveur d'autorisation redirigera le code d'autorisation vers l'adresse spécifiée dans l'élément de configuration redirectUri et transmettra le code d'autorisation sous la forme d'un paramètre GET. Nous pouvons demander un jeton d'accès au serveur d'autorisation via le code d'autorisation.

<?php
$code = $_GET['code'];
$token = $provider->getAccessToken('authorization_code', [
    'code' => $code
]);
echo $token->getToken();
?>

Dans le code ci-dessus, nous utilisons la méthode getAccessToken pour demander le jeton d'accès et transmettre le code d'autorisation en paramètre. Après avoir obtenu avec succès le jeton d'accès, nous pouvons obtenir la valeur du jeton d'accès via la méthode getToken.

  1. Actualiser le jeton d'accès

Lorsque le jeton d'accès expire, vous devez obtenir un nouveau jeton d'accès en actualisant le jeton. Dans oauth2-client, la méthode rafraîchirToken peut être utilisée pour actualiser le jeton.

<?php
$refreshToken = $token->getRefreshToken();
$newToken = $provider->getAccessToken('refresh_token', [
    'refresh_token' => $refreshToken
]);
echo $newToken->getToken();
?>

Dans le code ci-dessus, nous obtenons l'ancien jeton d'accès via la méthode getToken et l'actualisons via la méthode rafraîchirToken pour obtenir le nouveau jeton d'accès. Il est important de noter que le jeton d'actualisation n'est renvoyé que lorsqu'un jeton d'accès est obtenu.

3. Résumé

Cet article explique comment utiliser PHP pour intégrer le framework OAuth afin d'obtenir une autorisation d'accès à l'API tierce. Grâce à cette solution, nous pouvons facilement accéder aux API fournies par des tiers sans révéler le nom d'utilisateur et le mot de passe de l'utilisateur au tiers. Si vous devez implémenter une autorisation d'accès aux API tierces dans vos propres produits, vous pouvez vous référer au contenu décrit dans cet article. J'espère qu'il vous sera utile.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn