Cet article explore à l'aide de Guzzle, un client HTTP PHP, pour interagir avec les API nécessitant une authentification OAuth, se concentrant spécifiquement sur l'API de Twitter. Guzzle simplifie la mise en œuvre de l'OAuth en fournissant son propre abonné OAuth, éliminant le besoin de manipulation manuelle des flux de travail d'authentification complexes.
Points clés:
oauth-subscriber
. Avantage OAuth de Guzzle:
La construction de la fonctionnalité OAuth à partir de zéro est complexe. L'abonné OAuth intégré de Guzzle rationalise ce processus. Notez que Guzzle 4.x (ou supérieur) est requis; PHP 5.3 n'est plus pris en charge. Le compositeur simplifie la gestion des dépendances.
Configuration avec compositeur:
Le fichier composer.json
doit inclure:
{ "name": "johndoe/guzzle-twitter", "description": "PoC for Sitepoint article", "authors": [ { "name": "John Doe", "email": "john.doe@gmail.tst" } ], "minimum-stability": "dev", "require": { "guzzlehttp/guzzle": "6.*", //Updated to Guzzle 6.x "guzzlehttp/log-subscriber": "^1.0", //Updated to use caret for versioning "monolog/monolog": "^2.0", //Updated to use caret for versioning "guzzlehttp/oauth-subscriber": "^1.0" //Updated to use caret for versioning } }
Exécutez composer update
pour installer les packages nécessaires.
Exemple de code simplifié (OAuth à 1 patte):
Cet exemple démontre une approche OAuth à 1 patte, adaptée aux situations où l'autorisation spécifique à l'utilisateur n'est pas requise. N'oubliez pas de remplacer les espaces réservés par vos clés et jetons d'API Twitter.
<?php require 'vendor/autoload.php'; use GuzzleHttp\Client; use GuzzleHttp\Subscriber\Oauth\Oauth1; use GuzzleHttp\Subscriber\Log\LogSubscriber; use GuzzleHttp\Subscriber\Log\Formatter; use Monolog\Logger; use Monolog\Handler\StreamHandler; date_default_timezone_set('America/Phoenix'); $log = new Logger('guzzle'); $log->pushHandler(new StreamHandler('guzzle.log')); $subscriber = new LogSubscriber($log, Formatter::SHORT); $client = new Client(['base_uri' => 'https://api.twitter.com/', 'defaults' => ['auth' => 'oauth']]); $oauth = new Oauth1([ 'consumer_key' => '[your_consumer_key]', 'consumer_secret' => '[your_consumer_secret]', 'token' => '[your_access_token]', 'token_secret' => '[your_access_token_secret]' ]); $client->getEmitter()->attach($oauth); $client->getEmitter()->attach($subscriber); $res = $client->get('1.1/statuses/home_timeline.json')->json(); print_r($res); ?>
OAuth à 3 pattes (autorisation de l'utilisateur):
Pour OAuth à 3 pattes, qui nécessite une autorisation des utilisateurs, le processus implique plusieurs étapes:
Le code de ce processus est plus impliqué et nécessite la gestion des rappels et de la gestion de session (omis pour la concision, mais l'article d'origine fournit une implémentation détaillée).
Conclusion:
Guzzle simplifie considérablement l'intégration d'Oauth avec des API comme Twitter. Le choix entre OAuth à 1 patte et à 3 pattes dépend des exigences de votre demande. N'oubliez pas de toujours gérer attentivement les considérations de sécurité, en particulier lorsque vous traitez les informations d'identification des utilisateurs. L'article d'origine fournit des exemples de code complets sur github.
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!