curl_multi_exec
(PHP 5)
curl_multi_exec — Ejecuta las sub-conexiones del recurso cURL actual
Descripción
$mh
, int &$still_running
)Procesa 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.
Parámetros
-
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.
Valores devueltos
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.
Ejemplos
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);
?>
Ver también
- curl_multi_init() - Devuelve un nuevo multi recurso cURL
- curl_multi_select() - Espera actividad en cualquier conexión en curl_multi
- curl_exec() - Establece una sesión cURL