Игнорирование ошибок в файле 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;
}