抓取一般的页面没问题·。
但近期给一个网站个搞晕了·。请大神们帮帮忙看看是什么原因导致失败。谢谢
地址:http://183.36.249.82/
我们学校的图书馆。
我用的代码如下
<?php
header ( "Content-type: text/html; charset=utf-8" );
$url = "http://183.36.249.82/";
$contents = file_get_contents($url);
echo $contents;
?>
但会出现这个错误:
Server Error in '/' Application.
Runtime Error
我用的服务器是SAE。也试过用SAE提供的fetch
功能。
但可惜也是报错。
错误是:string(3) "500" string(21) "Internal Server Error"
多天研究原因不解。求解答。谢谢
PHP中文网2017-04-10 14:47:56
用file_get_contents
抓取的时候,一般要设置一下HTTP context.抓取网页还是用cURL比较好.
<?php
$header = <<<HEADER
Connection: keep-alive
Cache-Control: max-age=0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
User-Agent: Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/34.0.1847.116 Safari/537.36
DNT: 1
Referer: http://183.36.249.82/
Accept-Encoding: gzip,deflate,sdch
Accept-Language: zh-CN,zh;q=0.8
HEADER;
$context = stream_context_create(array(
'http' => array(
'method' => 'GET',
'header' => $header,
'timeout' => 10,
'protocol_version' => '1.1',
),
));
$contents = file_get_contents('http://183.36.249.82/', false, $context);
echo $contents;
阿神2017-04-10 14:47:56
你没发现网站要求重定向了吗?是刚学php呢吧?换用curl吧,file_get_contents抓不下来这个的吧(显然我错了,看别人的回答就知道是可以的,没文化真可怕啊)。
给你个参考连接吧,我不想写代码了
http://segmentfault.com/q/1010000000484804#a-1020000000484819
问问题的人虽然问得是ruby的问题,但是人家的php代码估计够你参考用了。