I’m trying to find a way to only quickly access a file and then disconnect immediately.
So I’ve decided to use cURL since it’s the fastest option for me. But I can’t figure out how I should “disconnect” cURL.
With the code below, Apache’s access logs says that the file I tried accessing was indeed accessed, but I’m feeling a little iffy about this, because when I just run the while loop without breaking out of it, it just keeps looping. Shouldn’t the loop stop when cURL has finished fetching the file? Or am I just being silly; is the loop just restarting constantly?
<?php
$Resource = curl_init();
curl_setopt($Resource, CURLOPT_URL, '...');
curl_setopt($Resource, CURLOPT_HEADER, 0);
curl_setopt($Resource, CURLOPT_USERAGENT, '...');
while(curl_exec($Resource)){
break;
}
curl_close($Resource);
?>
I tried setting the CURLOPT_CONNECTTIMEOUT_MS / CURLOPT_CONNECTTIMEOUT options to very small values, but it didn’t help in this case.
Is there a more “proper” way of doing this?
This statement is superflous:
Instead just keep the return value for future reference:
The
whileloop does not help anything. So now to your question: You can tellcurlthat it should only take some bytes from the body and then quit. That can be achieved by reducing theCURLOPT_BUFFERSIZEto a small value and by using a callback function to tell curl it should stop:Output:
Another alternative is to make a HEAD request by using
CURLOPT_NOBODYwhich will never fetch the body. But it’s not a GET request.The connect timeout settings are about how long it will take until the connect times out. The connect is the phase until the server accepts input from curl and curl starts to know about that the server does. It’s not related to the phase when curl fetches data from the server, that’s
You find a long list of available options in the PHP Manual:
curl_setoptDocs.