Отримання HTTP-коду в PHP за допомогою curl


177

Я використовую CURL для отримання статусу веб-сайту, якщо він перебуває вгору / вниз або перенаправляється на інший сайт. Я хочу зробити це настільки оптимізованим, але це не працює добре.

<?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;
?>

У мене це є функцією. Це працює чудово, але продуктивність не найкраща, оскільки він завантажує всю сторінку, в тому випадку, якщо я видалю $output = curl_exec($ch);її, вона повертається 0весь час.

Хтось знає, як покращити продуктивність?

Відповіді:


260

Спочатку переконайтеся, що URL-адреса дійсно дійсна (рядок, не порожній, хороший синтаксис), це швидко перевірити сторону сервера. Наприклад, зробити це спочатку можна заощадити багато часу:

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

Переконайтеся, що ви отримуєте лише заголовки, а не вміст тіла:

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

Щоб отримати докладніші відомості про отримання коду URL-статусу URL-адреси, я посилаюся на іншу посаду, яку я зробив (вона також допомагає при наступних переадресаціях):


В цілому:

$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;

4
Я відредагував вашу публікацію і вставив робочий зразок коду в цілому. Я вважаю це таким чином кориснішим. Btw., +1 для згадування налаштувань CURLOPT_HEADER та CURLOPT_NOBODY! :)
Sk8erPeter

25
Не потрібно встановлювати значення CURLOPT_HEADER на "true". Ви все одно отримаєте http code від curl_getinfo () в будь-якому випадку.
Brainware

7
Станом на PHP 5.5.0 та CURL 7.10.8, цей [CURLINFO_HTTP_CODE] є спадковим псевдонімом CURLINFO_RESPONSE_CODE ( ref )
sshow

Чомусь ця лінія curl_setopt($ch, CURLOPT_NOBODY, true);висить. Не впевнений, чи це пов’язано з версією PHP сервера.
іктоктоп

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;

16
Це найбільш пряма відповідь на питання
Enigma Plus

6
Цей не вимагає ігнорування тіла і робить лише один дзвінок, і це також є моєю бажаною відповіддю.
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"];

1
ви створили тип, він повинен бути echo $ info ["http_code"]; замість echo $ info ["http_code];
Ludo - Вимкнути запис


4

curl_getinfo - Отримайте інформацію щодо конкретного переказу

Перевірте 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);


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());

0

використовувати цей метод hitCurl для отримання всіх типів відповіді api, тобто 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
        ];
    }

Демонстраційна функція для тестування 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>";
    }

-3

Ось моє рішення потрібно отримати Status Http для регулярної перевірки стану сервера

$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);
}

1
Getheaders повільний порівняно з завиткою.
Майк Корменді

1
чому б ти не використовуєш cron або webhook замість сну та нескінченного циклу?
Угур Каздаль
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.