Pobieranie kodu HTTP w PHP za pomocą curl

177

Używam CURL, aby sprawdzić stan witryny, jeśli jest włączona / wyłączona lub przekierowuje do innej witryny. Chcę, aby był jak najbardziej uproszczony, ale nie działa dobrze.

<?php
$ch = curl_init($url);
curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch,CURLOPT_TIMEOUT,10);
$output = curl_exec($ch);
$httpcode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
curl_close($ch);

return $httpcode;
?>

Mam to zapakowane w funkcję. Działa dobrze, ale wydajność nie jest najlepsza, ponieważ pobiera całą stronę, jeśli $output = curl_exec($ch);usunę, 0cały czas wraca .

Czy ktoś wie, jak poprawić wydajność?

Aaran McGuire
źródło

Odpowiedzi:

260

Najpierw upewnij się, czy adres URL jest rzeczywiście prawidłowy (ciąg znaków, a nie pusty, dobra składnia). Można to szybko sprawdzić po stronie serwera. Na przykład zrobienie tego najpierw może zaoszczędzić dużo czasu:

if(!$url || !is_string($url) || ! preg_match('/^http(s)?:\/\/[a-z0-9-]+(.[a-z0-9-]+)*(:[0-9]+)?(\/.*)?$/i', $url)){
    return false;
}

Upewnij się, że pobierasz tylko nagłówki, a nie treść:

@curl_setopt($ch, CURLOPT_HEADER  , true);  // we want headers
@curl_setopt($ch, CURLOPT_NOBODY  , true);  // we don't need body

Aby uzyskać więcej informacji na temat uzyskiwania kodu http statusu adresu URL, odsyłam do innego posta, który napisałem (pomaga również w następujących przekierowaniach):


Jako całość:

$url = 'http://www.example.com';
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_HEADER, true);    // we want headers
curl_setopt($ch, CURLOPT_NOBODY, true);    // we don't need body
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch, CURLOPT_TIMEOUT,10);
$output = curl_exec($ch);
$httpcode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
curl_close($ch);

echo 'HTTP code: ' . $httpcode;
MoonLite
źródło
4
Zredagowałem Twój post i wkleiłem działający przykładowy kod jako całość. Uważam, że jest to bardziej pomocne. Przy okazji, +1 za wspomnienie ustawień CURLOPT_HEADER i CURLOPT_NOBODY! :)
Sk8erPeter,
25
Nie ma potrzeby ustawiania CURLOPT_HEADER na true. Nadal otrzymujesz kod http z curl_getinfo () tak czy inaczej.
Brainware
7
Od PHP 5.5.0 i cURL 7.10.8, ten [CURLINFO_HTTP_CODE] jest starszym aliasem CURLINFO_RESPONSE_CODE ( ref )
sshow
Z jakiegoś powodu ta linia curl_setopt($ch, CURLOPT_NOBODY, true);się zawiesza. Nie jestem pewien, czy jest to związane z wersją PHP serwera.
itoctopus
126
// must set $url first....
$http = curl_init($url);
// do your curl thing here
$result = curl_exec($http);
$http_status = curl_getinfo($http, CURLINFO_HTTP_CODE);
curl_close($http);
echo $http_status;
Deepika Patel
źródło
16
To jest najbardziej bezpośrednia odpowiedź na pytanie
Enigma Plus
6
Ten nie wymaga ignorowania ciała i wykonuje tylko jeden telefon, co czyni go również moją ulubioną odpowiedzią.
Mike_K
24
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.0)");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST,false);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER,false);
curl_setopt($ch, CURLOPT_MAXREDIRS, 10);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
curl_setopt($ch, CURLOPT_TIMEOUT, 20);
$rt = curl_exec($ch);
$info = curl_getinfo($ch);
echo $info["http_code"];
ntson1009
źródło
1
zrobiłeś typ, powinno to być echo $ info ["http_code"]; zamiast echo $ info ["http_code];
Ludo -
16

Wypróbuj funkcję PHP " get_headers ".

Coś w rodzaju:

<?php
    $url = 'http://www.example.com';
    print_r(get_headers($url));
    print_r(get_headers($url, 1));
?>
Raphael Caixeta
źródło
Pobieranie nagłówków jest powolne w porównaniu do zawijania.
Mike Kormendy
4

curl_getinfo - Uzyskaj informacje dotyczące konkretnego przelewu

Sprawdź curl_getinfo

<?php
// Create a curl handle
$ch = curl_init('http://www.yahoo.com/');

// Execute
curl_exec($ch);

// Check if any error occurred
if(!curl_errno($ch))
{
 $info = curl_getinfo($ch);

 echo 'Took ' . $info['total_time'] . ' seconds to send a request to ' . $info['url'];
}

// Close handle
curl_close($ch);
Główny programista
źródło
2

curl_execjest konieczne. Staraj CURLOPT_NOBODYsię nie pobierać treści. To mogłoby być szybsze.

Pigułki wybuchowe
źródło
0

function getStatusCode()
{
    $url = 'example.com/test';
    $ch = curl_init($url);
    curl_setopt($ch, CURLOPT_HEADER, true);    // we want headers
    curl_setopt($ch, CURLOPT_NOBODY, true);    // we don't need body
    curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
    curl_setopt($ch, CURLOPT_TIMEOUT,10);
    $output = curl_exec($ch);
    $httpcode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
    curl_close($ch);

    return  $httpcode;
}
print_r(getStatusCode());
mouhcine
źródło
0

użyj tej metody hitCurl do pobrania wszystkich typów odpowiedzi API, np. Get / Post

        function hitCurl($url,$param = [],$type = 'POST'){
        $ch = curl_init();
        if(strtoupper($type) == 'GET'){
            $param = http_build_query((array)$param);
            $url = "{$url}?{$param}";
        }else{
            curl_setopt_array($ch,[
                CURLOPT_POST => (strtoupper($type) == 'POST'),
                CURLOPT_POSTFIELDS => (array)$param,
            ]);
        }
        curl_setopt_array($ch,[
            CURLOPT_URL => $url,
            CURLOPT_RETURNTRANSFER => true,
        ]);
        $resp = curl_exec($ch);
        $statusCode = curl_getinfo($ch,CURLINFO_HTTP_CODE);
        curl_close($ch);
        return [
            'statusCode' => $statusCode,
            'resp' => $resp
        ];
    }

Funkcja demonstracyjna do testowania API

 function fetchApiData(){
        $url = 'https://postman-echo.com/get';
        $resp = $this->hitCurl($url,[
            'foo1'=>'bar1',
            'foo2'=>'bar2'
        ],'get');
        $apiData = "Getting header code {$resp['statusCode']}";
        if($resp['statusCode'] == 200){
            $apiData = json_decode($resp['resp']);
        }
        echo "<pre>";
        print_r ($apiData);
        echo "</pre>";
    }
Shamim
źródło
-3

Oto moje rozwiązanie, które wymaga uzyskania Status Http do regularnego sprawdzania stanu serwera

$url = 'http://www.example.com'; // Your server link

while(true) {

    $strHeader = get_headers($url)[0];

    $statusCode = substr($strHeader, 9, 3 );

    if($statusCode != 200 ) {
        echo 'Server down.';
        // Send email 
    }
    else {
        echo 'oK';
    }

    sleep(30);
}
christian Nguyen
źródło
1
Getheaders jest powolny w porównaniu do curl.
Mike Kormendy
1
dlaczego nie użyjesz crona lub webhooka zamiast uśpienia i nieskończonej pętli?
Ugur Kazdal