最近需要获取别人网站上的音乐数据。用了file_get_contents函数,但是总是会遇到获取失败的问题,尽管按照手册中的
例子设置了超时,可多数时候不会奏效:
$config['context'] = stream_context_create(array(‘http’
=> array(‘method’ =>
“GET”, ’timeout’ =>
5//这个超时时间不稳定,经常不奏效 ) )); 这时候,看一下服务器的连接池,会发现一堆类似的错误,让我头疼万分: file_get_contents(http://***): failed to open
stream… 现在改用了curl库,写了一个函数替换: function curl_file_get_contents($durl){ $ch =
curl_init(); curl_setopt($ch, CURLOPT_URL,
$durl); curl_setopt($ch,
CURLOPT_TIMEOUT, 5); curl_setopt($ch,
CURLOPT_USERAGENT, _USERAGENT_); curl_setopt($ch,
CURLOPT_REFERER,_REFERER_); curl_setopt($ch,
CURLOPT_RETURNTRANSFER, 1); $r =
curl_exec($ch); curl_close($ch); return
$r; } 如此,除了真正的网络问题外,没再出现任何问题。 这是别人做过的关于curl和file_get_contents的测试: file_get_contents抓取google.com需用秒数:
2.31319094
2.30374217 2.21512604 3.30553889 2.30124092 curl使用的时间:
0.68719101
0.64675593 0.64326 0.81983113 0.63956594 差距很大?呵呵,从我使用的经验来说,这两个工具不只是速度有差异,稳定性也相差很大。
建议对网络数据抓取稳定性要求比较高的朋友使用上面的
curl_file_get_contents函数,不但稳定速度快,还能假冒浏览器欺骗目标地址哦!
看到的其他文章收藏于此===============================
php
fsockopen
方法1:
用file_get_contents 以get方式获取内容
$url='http://www.domain.com/';
$html = file_get_contents($url);
echo $html;
?>
方法2:
用fopen打开url, 以get方式获取内容
$fp = fopen($url, 'r');
stream_get_meta_data($fp);
while(!feof($fp)) {
$result .= fgets($fp, 1024);
}
echo "url body: $result";
fclose($fp);
?>
方法3:用file_get_contents函数,以post方式获取url
$data = array ('foo' => 'bar');
$data = http_build_query($data);
$opts =
array (
'http' => array (
'method' => 'POST',
'header'=> "Content-type:
application/x-www-form-urlencoded\r\n" .
"Content-Length: " . strlen($data) . "\r\n",
'content' => $data
)
);
$context
= stream_context_create($opts);
$html = file_get_contents('http://localhost/e/admin/test.html',
false, $context);
echo
$html;
?>
方法4:用fsockopen函数打开url,以get方式获取完整的数据,包括header和body
function get_url ($url,$COOKIE=false)
{
$url = parse_url($url);
$query = $url[path]."?".$url[query];
echo "Query:".$query;
$fp = fsockopen( $url[host], $url[port]?$url[port]:80 , $errno,
$errstr, 30);
if (!$fp) {
return false;
} else {
$request = "GET $query HTTP/1.1\r\n";
$request .= "Host: $url[host]\r\n";
$request .= "Connection: Close\r\n";
if($COOKIE) $request.="COOKIE: $COOKIE\n";
$request.="\r\n";
fwrite($fp,$request);
while()) {
$result .= @fgets($fp, 1024);
}
fclose($fp);
return $result;
}
}
//获取url的html部分,去掉header
function GetUrlHTML($url,$COOKIE=false)
{
$rowdata = get_url($url,$COOKIE);
if($rowdata)
{
$body= stristr($rowdata,"\r\n\r\n");
$body=substr($body,4,strlen($body));
return $body;
}
return false;
}
?>
方法5:用fsockopen函数打开url,以POST方式获取完整的数据,包括header和body
function HTTP_Post($URL,$data,$COOKIE, $referrer="")
{
// parsing the given URL
$URL_Info=parse_url($URL);
// Building referrer
if($referrer=="") // if not given use this script as
referrer
$referrer="111";
// making string from $data
foreach($data as $key=>$value)
$values[]="$key=".urlencode($value);
$data_string=implode("&",$values);
// Find out which port is needed - if not given use standard
(=80)
if(!isset($URL_Info["port"]))
$URL_Info["port"]=80;
// building POST-request:
$request.="POST ".$URL_Info["path"]." HTTP/1.1\n";
$request.="Host: ".$URL_Info["host"]."\n";
$request.="Referer: $referer\n";
$request.="Content-type:
application/x-www-form-urlencoded\n";
$request.="Content-length: ".strlen($data_string)."\n";
$request.="Connection: close\n";
$request.="COOKIE: $COOKIE\n";
$request.="\n";
$request.=$data_string."\n";
$fp = fsockopen($URL_Info["host"],$URL_Info["port"]);
fputs($fp, $request);
while(!feof($fp)) {
$result .= fgets($fp, 1024);
}
fclose($fp);
return $result;
}
?>
方法6:使用curl库,使用curl库之前,可能需要查看一下php.ini是否已经打开了curl扩展
$ch = curl_init();
$timeout = 5;
curl_setopt ($ch, CURLOPT_URL, 'http://www.domain.com/');
curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
$file_contents = curl_exec($ch);
curl_close($ch);
echo
$file_contents;
?>
php中
curl, fsockopen ,file_get_contents 三个函数
都可以实现采集模拟发言 。
三者有什么区别,或者讲究么
=============================================================================
以下PHP抓取网页内容的范例是通curl_init函数来获取163天气预报
把php.ini里(
;extension=php_curl.dll ) 前面的(;)去掉保存
把php_curl.dll,libeay32.dll,ssleay32.dll拷到c:\windows\system32里,重启IIS即可,没有装apache
//www.163.com/weatherxml/54511.xml"); //要求CURL返回数据 curl_setopt($ch,CURLOPT_RETURNTRANSFER,1); //执行请求 $result = curl_exec($ch) or die (curl_error()); //取得返回的结果,并显示 //echo $result; // echo curl_error($ch); $qx=explode("\"",strstr($result,"qx=")); $wd=explode("\"",strstr($result,"wd=")); $qximg=explode("\"",strstr($result,"qximg=")); $qximg_=explode(",",$qximg[1]); echo "北京 ".$qx[1].""; echo $wd[1]; //关闭CURL curl_close($ch); ?>