curl_multi_add_handle

(PHP 5, PHP 7, PHP 8)

curl_multi_add_handleAjoute une ressource cURL à un cURL multiple

Description

curl_multi_add_handle(CurlMultiHandle$multi_handle, CurlHandle$handle): int

Ajoute la session handle au gestionnaire multiple multi_handle

Liste de paramètres

multi_handle

Un gestionnaire cURL multiple retourné par curl_multi_init().

handle

Un gestionnaire cURL retourné par curl_init().

Valeurs de retour

Retourne 0 en cas de succès, ou un des codes erreurs CURLM_XXX.

Historique

VersionDescription
8.0.0multi_handle attend désormais une instance de CurlMultiHandle; auparavant; une resource était attendue.
8.0.0handle attend désormais une instance de CurlHandle; auparavant; une resource était attendue.

Exemples

Exemple #1 Exemple avec curl_multi_add_handle()

Cet exemple crée deux gestionnaires cURL, les ajoute à un gestionnaire multiple, et les exécute de façon asynchrone.

<?php
// Création des ressources cURL
$ch1 = curl_init();
$ch2 = curl_init();

// Définit l'URL ainsi que d'autres options
curl_setopt($ch1, CURLOPT_URL, "http://www.example.com/");
curl_setopt($ch1, CURLOPT_HEADER, 0);
curl_setopt($ch2, CURLOPT_URL, "http://www.php.net/");
curl_setopt($ch2, CURLOPT_HEADER, 0);

// Création du gestionnaire cURL multiple
$mh = curl_multi_init();

// Ajoute les deux gestionnaires
curl_multi_add_handle($mh,$ch1);
curl_multi_add_handle($mh,$ch2);

// Exécute le gestionnaire multiple
do {
$status = curl_multi_exec($mh, $active);
if (
$active) {
curl_multi_select($mh);
}
} while (
$active && $status == CURLM_OK);

// Ferme tous les gestionnaires
curl_multi_remove_handle($mh, $ch1);
curl_multi_remove_handle($mh, $ch2);
curl_multi_close($mh);
?>

Voir aussi

To Top