Игнорирование ошибок в файле get contents HTTP wrapper?

следующий код-запросить онлайн-тезаурус для поисковой системы, которую я создаю как проект колледжа, но у меня проблемы с file_get_contents "не удалось открыть поток" ошибки. Когда я посылаю слово, которое тезаурус не распознает, он выдает ошибку. Я пытаюсь написать кусок кода игнорировать ошибку и просто продолжайте без информации.

$thesaurus_search="http://words.bighugelabs.com/api/2/0089388bb57f/".$this->formatted_query."/php";
$result_thesaurus=file_get_contents($thesaurus_search);

пробовал:

if (file_get_contents($thesaurus_search) != NULL)
{ // do stuff }

...но это не работает, потому что это все равно возвращает какую-то строку.

что я могу сделать, чтобы справиться с подобными ситуациями?

4 ответов


Если вы не хотите file_get_contents в отчете ошибки HTTP как предупреждения PHP, то это очистить способ сделать это, используя контекст потока (есть что-то специально для):

$context = stream_context_create(array(
    'http' => array('ignore_errors' => true),
));

$result = file_get_contents('http://your/url', false, $context);

самое простое решение, если вы в порядке с просто вычерпывание, было бы:

if (empty($thesaurus_search)) { 
   return;
} else {
   //process with value
}

чтобы более полно справиться с этим, глядя на API, похоже, вы должны проверить заголовок ответа, например:

$thesaurus_search="http://words.bighugelabs.com/api/2/0089388bb57f/".$this->formatted_query."/php";
$result_thesaurus=file_get_contents($thesaurus_search);
if ($http_response_header[0] = 'HTTP/1.1 200 OK') {
    //code to handle words
} else {
    // do something else?
}

Если я правильно вас понимаю, вы пытаетесь сделать вызов API для http://words.bighugelabs.com. Для этого вам нужен cURL, поэтому, если у вас установлен cURL, этот код будет работать для вас.

$ch = curl_init();
$thesaurus_search="http://words.bighugelabs.com/api/2/0089388bb57f/".$this->formatted_query."/php";
$options = array();
$options[CURLOPT_URL] = $thesaurus_search;
$options[CURLOPT_RETURNTRANSFER] = true;
curl_setopt_array($ch, $options);

// Print result.
print_r(curl_close($ch));

вы можете попробовать curl:

function curl_get_contents($url) {
    $ch = curl_init($url);
    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
    curl_setopt($ch, CURLOPT_HEADER, 0);
    curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)");
    curl_setopt($ch, CURLOPT_MAXREDIRS, 2); 
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    $content = curl_exec($ch);
    curl_close($ch);
    return $content;
}