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.

Замечание:

Функция возвращает ошибки, которые относятся только к мультистеку. Даже когда функция возвращает код CURLM_OK, ошибки при отдельных передачах не исключаются.

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

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

Примеры

Пример #1 Пример запуска субсоединений текущего cURL-дескриптора функцией curl_multi_exec()

Пример создаст cURL-дескрипторы для списка URL-адресов, добавит каждый дескриптор в мультидескриптор и обработает дескрипторы асинхронно.

<?php

$urls
= [
"https://www.php.net/",
"https://www.example.com/",
];

$mh = curl_multi_init();
$map = new WeakMap();

foreach (
$urls as $url) {
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_multi_add_handle($mh, $ch);
$map[$ch] = $url;
}

do {
$status = curl_multi_exec($mh, $unfinishedHandles);
if (
$status !== CURLM_OK) {
throw new
\Exception(curl_multi_strerror(curl_multi_errno($mh)));
}

while ((
$info = curl_multi_info_read($mh)) !== false) {
if (
$info['msg'] === CURLMSG_DONE) {
$handle = $info['handle'];
curl_multi_remove_handle($mh, $handle);
$url = $map[$handle];

if (
$info['result'] === CURLE_OK) {
$statusCode = curl_getinfo($handle, CURLINFO_HTTP_CODE);

echo
"Запрос по адресу {$url} завершился и вернул HTTP-статус {$statusCode}:", PHP_EOL;
echo
curl_multi_getcontent($handle);
echo
PHP_EOL, PHP_EOL;
} else {
echo
"Запрос по адресу {$url} завершился ошибкой: ", PHP_EOL;
echo
curl_strerror($info['result']);
echo
PHP_EOL, PHP_EOL;
}
}
}

if (
$unfinishedHandles) {
if ((
$updatedHandles = curl_multi_select($mh)) === -1) {
throw new
\Exception(curl_multi_strerror(curl_multi_errno($mh)));
}
}
} while (
$unfinishedHandles);

curl_multi_close($mh);

?>

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

  • curl_multi_init() - Возвращает новый мультидескриптор модуля cURL
  • curl_multi_select() - Ждёт, пока хотя в одном соединении мультидескриптора cURL не станут возможными считывание или запись данных
  • curl_exec() - Выполняет сеанс сетевой передачи данных