我可能不应该使用 file_get_contents() 我应该使用什么?我想保持简单。
Warning: file_get_contents(http://en.wikipedia.org/w/api.php?action=query&titles=Your_Highness&prop=revisions&rvprop=content&rvsection=0): failed to open stream: HTTP request failed! HTTP/1.0 403 Forbidden
最佳答案
您在这里遇到的问题与 MW API 的 User-Agent policy 有关。 - 您必须提供 User-Agent
header ,并且该 header 必须提供某种与您联系的方式。
您可以使用 file_get_contents()
和 stream context 来完成此操作:
$opts = array('http' =>
array(
'user_agent' => 'MyBot/1.0 (http://www.mysite.com/)'
)
);
$context = stream_context_create($opts);
$url = 'http://en.wikipedia.org/w/api.php?action=query&titles=Your_Highness&prop=revisions&rvprop=content&rvsection=0';
var_dump(file_get_contents($url, FALSE, $context));
话虽如此,使用 cURL 可能被认为更“标准”。 ,这肯定会给你更多的控制权:
$url = 'http://en.wikipedia.org/w/api.php?action=query&titles=Your_Highness&prop=revisions&rvprop=content&rvsection=0';
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
curl_setopt($ch, CURLOPT_USERAGENT, 'MyBot/1.0 (http://www.mysite.com/)');
$result = curl_exec($ch);
if (!$result) {
exit('cURL Error: '.curl_error($ch));
}
var_dump($result);
关于php - 如何使用 PHP 从 Wikipedia API 获取结果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8956331/