Manuel PHP
curl_multi_exec
(PHP 5)
curl_multi_exec — Exécute les sous-requêtes de la session cURL
Description
Exécute chaque gestionnaire de la pile. Cette méthode peut être appelée même si un gestionnaire à besoin de lire ou d'écrire des données.
Liste de paramètres
- mh
-
Un gestionnaire cURL multiple retourné par la fonction 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 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.
Exemples
Exemple #1 Exemple avec curl_multi_exec()
Cet exemple crée deux gestionnaires cURL, les ajoute à un gestionnaire multiple, et les exécute en parallèle.
- <?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://lxr.php.net/");
- 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 multiple
- $mh = curl_multi_init();
- // Ajoute les deux gestionnaires
- curl_multi_add_handle($mh,$ch1);
- curl_multi_add_handle($mh,$ch2);
- $active = null;
- // Exécute le gestionnaire
- do {
- $mrc = curl_multi_exec($mh, $active);
- } while ($mrc == CURLM_CALL_MULTI_PERFORM);
- while ($active && $mrc == CURLM_OK) {
- if (curl_multi_select($mh) != -1) {
- do {
- $mrc = curl_multi_exec($mh, $active);
- } while ($mrc == CURLM_CALL_MULTI_PERFORM);
- }
- }
- // Ferme les gestionnaires
- curl_multi_remove_handle($mh, $ch1);
- curl_multi_remove_handle($mh, $ch2);
- curl_multi_close($mh);
- ?>
Remonter 
