Maison développement back-end tutoriel php Comment PHP utilise-t-il des API tierces pour l'interaction des données ?

Comment PHP utilise-t-il des API tierces pour l'interaction des données ?

Jun 29, 2023 am 09:45 AM
php 第三方api 数据交互

Comment PHP utilise-t-il des API tierces pour l'interaction des données ?

Avec le développement d'Internet, de nombreux sites Web et applications doivent interagir avec des API tierces pour obtenir et traiter des données externes. En tant que langage de script côté serveur populaire, PHP dispose de puissantes capacités pour gérer ces interactions de données. Cet article présentera comment PHP utilise des API tierces pour l'interaction des données.

API tierce (Application Programming Interface) fait référence aux interfaces fournies par d'autres organisations ou services, à travers lesquelles les fonctions et les données de l'organisation ou du service sont accessibles. Par exemple, l'API d'un site Web de réseau social peut être utilisée pour obtenir des informations sur les utilisateurs, publier des messages et d'autres fonctions, et l'API d'une passerelle de paiement peut être utilisée pour traiter les demandes de paiement et d'autres fonctions.

Avant d'utiliser l'API tierce, nous devons obtenir les informations d'identification d'accès à l'API. Habituellement, les fournisseurs d'API nous demandent d'enregistrer un compte et de fournir certaines informations d'authentification d'identité, telles que des clés ou des jetons API. Ces informations d'identification seront utilisées pour identifier notre application et nous autoriser à utiliser les fonctionnalités de l'API.

Une fois que nous avons les informations d'accès à l'API, nous pouvons commencer à écrire du code en PHP pour l'interaction des données.

Tout d'abord, nous devons envoyer des requêtes HTTP via l'extension cURL ou en utilisant une bibliothèque client HTTP telle que GuzzleHTTP. L'extension cURL pour PHP est un outil puissant pour communiquer avec les serveurs. Si nous choisissons d'utiliser GuzzleHTTP, il peut être installé via Composer :

composer require guzzlehttp/guzzle
Copier après la connexion

Ce qui suit est un exemple de code qui utilise l'extension cURL pour envoyer une requête GET :

$curl = curl_init();
$url = 'https://api.example.com/data';
$apiKey = 'YOUR_API_KEY';

$options = array(
    CURLOPT_URL => $url,
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_HTTPHEADER => array(
        'Authorization: Bearer ' . $apiKey
    )
);

curl_setopt_array($curl, $options);
$result = curl_exec($curl);
curl_close($curl);

$data = json_decode($result, true);
Copier après la connexion

In le code ci-dessus, nous initialisons d'abord une session cURL et définissons l'URL et la clé API demandées. Nous configurons ensuite la session cURL en définissant un tableau d'options. Dans cet exemple, nous utilisons l'option CURLOPT_RETURNTRANSFER pour spécifier que les résultats sont renvoyés au lieu d'être affichés directement sur la page. Nous définissons également l'en-tête d'autorisation HTTP via l'option CURLOPT_HTTPHEADER pour vérifier notre accès API. Enfin, nous effectuons la requête cURL, fermons la session et décodons les résultats renvoyés en données au format JSON.

Si nous utilisons la bibliothèque GuzzleHTTP, la même requête GET peut être écrite comme ceci :

use GuzzleHttpClient;

$apiUrl = 'https://api.example.com/data';
$apiKey = 'YOUR_API_KEY';

$client = new Client([
    'headers' => [
        'Authorization' => 'Bearer ' . $apiKey
    ]
]);

$response = $client->get($apiUrl);
$data = json_decode($response->getBody(), true);
Copier après la connexion

Le code ci-dessus crée un objet client GuzzleHTTP et ajoute l'indicateur d'autorisation en définissant le tête d'option d'en-têtes. Ensuite, nous envoyons une requête GET à l'aide de la méthode get() et décodons enfin le corps de la réponse renvoyé en données au format JSON.

Pour les requêtes POST, nous pouvons utiliser la méthode post() de cURL ou GuzzleHTTP pour envoyer des données. Voici un exemple de code qui utilise l'extension cURL pour envoyer une requête POST :

$curl = curl_init();
$url = 'https://api.example.com/data';
$apiKey = 'YOUR_API_KEY';
$data = array(
    'key1' => 'value1',
    'key2' => 'value2'
);

$options = array(
    CURLOPT_URL => $url,
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_HTTPHEADER => array(
        'Authorization: Bearer ' . $apiKey,
        'Content-Type: application/json'
    ),
    CURLOPT_POST => true,
    CURLOPT_POSTFIELDS => json_encode($data)
);

curl_setopt_array($curl, $options);
$result = curl_exec($curl);
curl_close($curl);

$response = json_decode($result, true);
Copier après la connexion

Dans le code ci-dessus, nous définissons l'option CURLOPT_POST sur true et spécifions les données de la requête POST via l'option CURLOPT_POSTFIELDS . Nous indiquons également que les données sont au format JSON en définissant l'en-tête Content-Type sur application/json.

De même, si nous utilisons la bibliothèque GuzzleHTTP, la même requête POST peut être écrite comme ceci :

use GuzzleHttpClient;

$apiUrl = 'https://api.example.com/data';
$apiKey = 'YOUR_API_KEY';
$data = array(
    'key1' => 'value1',
    'key2' => 'value2'
);

$client = new Client([
    'headers' => [
        'Authorization' => 'Bearer ' . $apiKey,
        'Content-Type' => 'application/json'
    ]
]);

$response = $client->post($apiUrl, ['json' => $data]);
$result = json_decode($response->getBody(), true);
Copier après la connexion

Dans le code ci-dessus, nous utilisons la méthode post() pour envoyer la requête POST et passe L'option ['json' => $data] envoie les données au format JSON.

Ci-dessus sont quelques exemples de codes de base qui montrent comment utiliser PHP pour interagir avec des API tierces pour les données. En fait, l'utilisation de chaque API sera différente et le processus d'exploitation et d'autorisation spécifique devra faire référence à la documentation du fournisseur d'API. Cependant, en comprenant les concepts de base et l'exemple de code ci-dessus, nous devrions être mieux en mesure de commencer à intégrer des API tierces pour nos applications.

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 de ce site Web
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Configuration du projet CakePHP Configuration du projet CakePHP Sep 10, 2024 pm 05:25 PM

Dans ce chapitre, nous comprendrons les variables d'environnement, la configuration générale, la configuration de la base de données et la configuration de la messagerie dans CakePHP.

Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Dec 24, 2024 pm 04:42 PM

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.

CakePHP travaillant avec la base de données CakePHP travaillant avec la base de données Sep 10, 2024 pm 05:25 PM

Travailler avec la base de données dans CakePHP est très simple. Nous comprendrons les opérations CRUD (Créer, Lire, Mettre à jour, Supprimer) dans ce chapitre.

Date et heure de CakePHP Date et heure de CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler avec la date et l'heure dans cakephp4, nous allons utiliser la classe FrozenTime disponible.

Téléchargement de fichiers CakePHP Téléchargement de fichiers CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

Routage CakePHP Routage CakePHP Sep 10, 2024 pm 05:25 PM

Dans ce chapitre, nous allons apprendre les sujets suivants liés au routage ?

Discuter de CakePHP Discuter de CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

CakePHP créant des validateurs CakePHP créant des validateurs Sep 10, 2024 pm 05:26 PM

Le validateur peut être créé en ajoutant les deux lignes suivantes dans le contrôleur.

See all articles