(PHP 5, PHP 7)
curl_multi_exec — Ejecuta las sub-conexiones del recurso cURL actual
$mh
, int &$still_running
) : intProcesa cada uno de los recursos del grupo. Este método puede ser llamado cuando el recurso tenga o no tenga que leer o escribir datos.
mh
El multi recurso cURL multi devuelto por curl_multi_init().
still_running
Hace referencia a una bandera que dice cuando las operaciones siguen ejecutándose.
Código cURL definido en las Constantes predefinidas cURL.
Nota:
Solo devuelve errores en relación con el grupo. Es posible que hayan ocurrido problemas en transferencias individuales aunque esta función devuelva
CURLM_OK
.
Ejemplo #1 curl_multi_exec() example
Este ejemplo creará dos recursos cURL, los añadirá al grupo de recursos y los ejecutará de forma asíncrona.
<?php
// Crea los dos recursos cURL
$ch1 = curl_init();
$ch2 = curl_init();
// Establecer la URL y otras opciones apropiadas
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);
// Crea el recurso cURL múltiple
$mh = curl_multi_init();
// Añade los dos recursos
curl_multi_add_handle($mh,$ch1);
curl_multi_add_handle($mh,$ch2);
$active = null;
// Ejecuta los recursos
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);
}
}
// Cierra los recursos
curl_multi_remove_handle($mh, $ch1);
curl_multi_remove_handle($mh, $ch2);
curl_multi_close($mh);
?>