It is always a good idea to use curl_close() on all individual curl handles after executing curl_multi_remove_handle(). This will free up additional memory resources. So, a typical code would look like:
<?php
$ch1 = curl_init();
curl_setopt($ch1, CURLOPT_URL, 'http://www.example.com/');
curl_setopt($ch1, CURLOPT_RETURNTRANSFER, true);
$ch2 = curl_init();
curl_setopt($ch2, CURLOPT_URL, 'http://www.example.net/');
curl_setopt($ch2, CURLOPT_RETURNTRANSFER, true);
$mh = curl_multi_init();
curl_multi_add_handle($mh, $ch1);
curl_multi_add_handle($mh, $ch2);
$active = null;
do {
curl_multi_exec($mh, $active);
}
while($active);
$res1 = curl_multi_getcontent($ch1);
$res2 = curl_multi_getcontent($ch2);
curl_multi_remove_handle($mh, $ch1);
curl_multi_remove_handle($mh, $ch2);
curl_multi_close($mh);
curl_close($ch1);
curl_close($ch2);
?>
curl_multi_remove_handle
(PHP 5)
curl_multi_remove_handle — Retire un cURL multiple d'un jeu de cURL
Description
int curl_multi_remove_handle
( resource
$mh
, resource $ch
)
Retire un gestionnaire ch donné du gestionnaire
mh. Lorsque le gestionnaire ch
a été retiré, il est de nouveau parfaitement correct d'exécuter la fonction
curl_exec() sur ce gestionnaire. Le fait de retirer
le gestionnaire ch en cours d'utilisation stoppe tous
les transferts en cours.
Liste de paramètres
-
mh -
Un gestionnaire cURL multiple retourné par la fonction curl_multi_init().
-
ch -
Un gestionnaire cURL retourné par la fonction curl_init().
Valeurs de retour
Retourne 0 en cas de succès, ou un des codes erreurs
CURLM_XXX.
Voir aussi
- curl_init() - Initialise une session cURL
- curl_multi_init() - Retourne un nouveau cURL multiple
- curl_multi_add_handle() - Ajoute une ressource cURL à un cURL multiple
mercury at caucasus dot net
23-Jun-2010 04:00
