curl_multi_exec

(PHP 5, PHP 7, PHP 8)

curl_multi_execЗапускает подсоединения текущего дескриптора cURL

Описание

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

Обрабатывает каждый дескриптор в стеке. Этот метод может быть вызван вне зависимости от необходимости дескриптора читать или записывать данные.

Список параметров

multi_handle

Мультидескриптор cURL, полученный из curl_multi_init().

still_running

Ссылка на флаг, указывающий, идут ли ещё какие-либо действия.

Возвращаемые значения

Код cURL, указанный в предопределённых константах cURL.

Замечание:

Здесь возвращаются ошибки, относящиеся только ко всему стеку. Проблемы всё ещё могут произойти на индивидуальных запросах, даже когда эта функция возвращает CURLM_OK.

Список изменений

ВерсияОписание
8.0.0multi_handle теперь ожидает экземпляр; раньше, ожидался ресурс (resource).

Примеры

Пример #1 Пример использования curl_multi_exec()

Этот пример создаст два дескриптора cURL, добавит их в набор дескрипторов, а затем запустит их асинхронно.

<?php
// создаём оба ресурса cURL
$ch1 = curl_init();
$ch2 = curl_init();

// устанавливаем URL и другие соответствующие опции
curl_setopt($ch1, CURLOPT_URL, "http://example.com/");
curl_setopt($ch1, CURLOPT_HEADER, 0);
curl_setopt($ch2, CURLOPT_URL, "http://www.php.net/");
curl_setopt($ch2, CURLOPT_HEADER, 0);

//создаём набор дескрипторов cURL
$mh = curl_multi_init();

//добавляем два дескриптора
curl_multi_add_handle($mh,$ch1);
curl_multi_add_handle($mh,$ch2);

//запускаем множественный обработчик
do {
$status = curl_multi_exec($mh, $active);
if (
$active) {
// Ждём какое-то время для оживления активности
curl_multi_select($mh);
}
} while (
$active && $status == CURLM_OK);

//закрываем дескрипторы
curl_multi_remove_handle($mh, $ch1);
curl_multi_remove_handle($mh, $ch2);
curl_multi_close($mh);

?>

Смотрите также

To Top