


L'intégration PHP et OAuth implémente une autorisation d'accès aux API tierces
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 :
- Inscription du client : le client s'inscrit auprès du serveur d'autorisation et demande un identifiant client et une clé secrète client.
- 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.
- 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.
- Obtenir l'autorisation : le serveur d'autorisation émet un jeton d'accès et un jeton d'actualisation au client.
- 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.
- 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.
- 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
- 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.
- 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.
- 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.
- 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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

Si vous êtes un développeur PHP expérimenté, vous aurez peut-être le sentiment d'y être déjà allé et de l'avoir déjà fait. Vous avez développé un nombre important d'applications, débogué des millions de lignes de code et peaufiné de nombreux scripts pour réaliser des opérations.

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total

Liaison statique (statique: :) implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

Quelles sont les méthodes magiques de PHP? Les méthodes magiques de PHP incluent: 1. \ _ \ _ Construct, utilisé pour initialiser les objets; 2. \ _ \ _ Destruct, utilisé pour nettoyer les ressources; 3. \ _ \ _ Appel, gérer les appels de méthode inexistants; 4. \ _ \ _ GET, Implémentez l'accès à l'attribut dynamique; 5. \ _ \ _ SET, Implémentez les paramètres d'attribut dynamique. Ces méthodes sont automatiquement appelées dans certaines situations, améliorant la flexibilité et l'efficacité du code.
