(PHP 5, PHP 7)
curl_multi_exec — Führt die Unter-Verbindungen des cURL-Handles aus
$mh
, int &$still_running
) : intVerarbeitet alle Handles; diese Methode kann unabhängig davon aufgerufen werden, ob eines der Handles Daten lesen oder schreiben muß.
mh
Ein von curl_multi_init() zurückgegebenes cURL-Multihandle.
still_running
Eine Referenz auf ein Flag um festzustellen, ob auf einem oder mehreren Handles noch gearbeitet wird.
Ein cURL-Code der in den cURL Vordefinierten Konstanten definiert ist.
Hinweis:
Es werden nur Fehler zurückgegeben, die den Handle-Stack betreffen. Auch wenn
CURLM_OK
zurückgegeben wird können auf einzelnen Handles Fehler aufgetreten sein.
Beispiel #1 curl_multi_exec()-Beispiel
In diesem Beispiel werden zwei cURL-Handles erstellt, einem Mehrfach-Handle hinzugefügt und anschließend asynchron ausgeführt.
<?php
// zwei cURL Resourcen erstellen
$ch1 = curl_init();
$ch2 = curl_init();
// URL und weitere Optionen setzen
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);
// Mehrfach-Handle erstellen
$mh = curl_multi_init();
// die zuvor erstellten Handles hinzufügen
curl_multi_add_handle($mh,$ch1);
curl_multi_add_handle($mh,$ch2);
// Mehrfach-Handle ausführen
do {
$status = curl_multi_exec($mh, $active);
if ($active) {
// Einen Moment auf weitere Aktivität warten
curl_multi_select($mh);
}
} while ($active && $status == CURLM_OK);
// Alle Handles schließen
curl_multi_remove_handle($mh, $ch1);
curl_multi_remove_handle($mh, $ch2);
curl_multi_close($mh);
?>