curl_multi_exec

(PHP 5, PHP 7, PHP 8)

curl_multi_execExécute les sous-requêtes de la session cURL

Description

function curl_multi_exec(CurlMultiHandle $multi_handle, int &$still_running): int

Exécute chaque gestionnaire de la pile. Cette méthode peut être appelée même si un gestionnaire a besoin de lire ou d'écrire des données.

Liste de paramètres

multi_handle
Un gestionnaire cURL multiple retourné par curl_multi_init().
still_running

Une référence à un drapeau, qui annonce si les opérations sont toujours en cours.

Valeurs de retour

Un code cURL, défini dans les constantes prédéfinies cURL.

Note:

Cette fonction ne retourne que des erreurs au regard de la pile. Des problèmes surviennent toujours sur des transferts individuels même lorsque cette fonction retourne CURLM_OK.

Historique

Version Description
8.0.0 multi_handle attend désormais une instance de CurlMultiHandle; auparavant; une resource était attendue.

Exemples

Exemple #1 Exemple avec curl_multi_exec()

Cet exemple créera des gestionnaires cURL pour une liste d'URLs, les ajoutera à un gestionnaire multiple, et les exécutera de façon asynchrone.

<?php
$urls = [
    "https://www.php.net/",
    "https://www.example.com/",
];

$mh = curl_multi_init();
$map = new WeakMap();

foreach ($urls as $url) {
    $ch = curl_init($url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_multi_add_handle($mh, $ch);
    $map[$ch] = $url;
}

do {
    $status = curl_multi_exec($mh, $unfinishedHandles);
    if ($status !== CURLM_OK) {
        throw new \Exception(curl_multi_strerror(curl_multi_errno($mh)));
    }

    while (($info = curl_multi_info_read($mh)) !== false) {
        if ($info['msg'] === CURLMSG_DONE) {
            $handle = $info['handle'];
            curl_multi_remove_handle($mh, $handle);
            $url = $map[$handle];

            if ($info['result'] === CURLE_OK) {
                $statusCode = curl_getinfo($handle, CURLINFO_HTTP_CODE);

                echo "La requête à {$url} est terminée avec le statut HTTP {$statusCode} :", PHP_EOL;
                echo curl_multi_getcontent($handle);
                echo PHP_EOL, PHP_EOL;
            } else {
                echo "La requête à {$url} a échoué avec l'erreur : ", PHP_EOL;
                echo curl_strerror($info['result']);
                echo PHP_EOL, PHP_EOL;
            }
        }
    }

    if ($unfinishedHandles) {
        if (($updatedHandles = curl_multi_select($mh)) === -1) {
            throw new \Exception(curl_multi_strerror(curl_multi_errno($mh)));
        }
    }
} while ($unfinishedHandles);

curl_multi_close($mh);

?>

Voir aussi

  • curl_multi_init() - Retourne un nouveau gestionnaire cURL multiple
  • curl_multi_select() - Attend jusqu'à ce que la lecture ou l'écriture soit possible pour toute connexion de handle cURL multi
  • curl_exec() - Exécute une session cURL