If you want to fetch the error message, make sure you fetch it before you close the current cURL session or the error message will be reset to an empty string.
(PHP 4 >= 4.0.3, PHP 5, PHP 7, PHP 8)
curl_error — Gibt einen String zurück, der den letzten Fehler der aktuellen Session enthält
Gibt eine Fehlermeldung in Klartext für die letzte cURL-Operation zurück.
Gibt die Fehlermeldung oder, falls kein Fehler aufgetreten ist,
''
(den leeren String) zurück.
Version | Beschreibung |
---|---|
8.0.0 |
handle erwartet nun eine
CurlHandle-Instanz; vorher wurde eine
Ressource erwartet.
|
Beispiel #1 curl_error()-Beispiel
<?php
// Eine cURL-Ressource für ein nicht existierendes Ziel erstellen
$ch = curl_init('http://404.php.net/');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
if(curl_exec($ch) === false)
{
echo 'Curl-Fehler: ' . curl_error($ch);
}
else
{
echo 'Operation ohne Fehler vollständig ausgeführt';
}
// Ressource schließen
curl_close($ch);
?>
If you want to fetch the error message, make sure you fetch it before you close the current cURL session or the error message will be reset to an empty string.
If you're using curl_multi and there's an error, curl_error() will remain empty until you've called curl_multi_info_read(). That function "pumps" the information inside the curl libraries to the point where curl_error() will return a useful string.
This should really be added to the documentation, because it's not at all obvious.
For a 404 response to actually trigger an error as the example seems to be trying to demonstrate the following option should be set:
curl_setopt($ch,CURLOPT_FAILONERROR,true);
As per http://curl.haxx.se/libcurl/c/libcurl-errors.html
CURLE_HTTP_RETURNED_ERROR (22)
This is returned if CURLOPT_FAILONERROR is set TRUE and the HTTP server returns an error code that is >= 400. (This error code was formerly known as CURLE_HTTP_NOT_FOUND.)
curl_error is not a textual representation of curl_errno.
It's an actual error *message*.
If you want textual representation of error *code*, look for curl_strerror.