curl_multi_exec

(PHP 5, PHP 7)

curl_multi_execEjecuta las sub-conexiones del recurso cURL actual

Descripción

curl_multi_exec ( resource $mh , int &$still_running ) : int

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($ch1CURLOPT_URL"http://lxr.php.net/");
curl_setopt($ch1CURLOPT_HEADER0);
curl_setopt($ch2CURLOPT_URL"http://www.php.net/");
curl_setopt($ch2CURLOPT_HEADER0);

// 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