curl_multi_exec
(PHP 5, PHP 7, PHP 8)
curl_multi_exec — Führt die Unter-Verbindungen des cURL-Handles aus
Beschreibung
Verarbeitet alle Handles; diese Methode kann unabhängig davon aufgerufen werden, ob eines der Handles Daten lesen oder schreiben muß.
Parameter-Liste
-
multi_handle
-
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.
Rückgabewerte
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.
Changelog
Version | Beschreibung |
---|---|
8.0.0 |
multi_handle erwartet nun eine
CurlMultiHandle-Instanz; vorher wurde eine
Ressource erwartet.
|
Beispiele
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);
?>
Siehe auch
- curl_multi_init() - Liefert ein cURL-Mehrfach-Handle
- curl_multi_select() - Alle Sockets abfragen, die mit der cURL Erweiterung assoziiert sind und ausgewählt werden können
- curl_exec() - Eine cURL-Session ausführen