您的位置:首页 > 理论基础 > 计算机网络

php读取网络文件(curl, fsockopen ,file_get_contents 几个方法的效率对比)

2013-01-23 14:21 771 查看
最近需要获取别人网站上的音乐数据。用了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方式获取内容

<?php

$url='http://www.domain.com/';

$html = file_get_contents($url);

echo $html;

?>
方法2: 用fopen打开url, 以get方式获取内容

<?php

$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

<?php

$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
<?php

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
<?php

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扩展
<?php

$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
< ?php
//初始化curl
$ch = curl_init() or die (curl_error());
//设置URL参数
curl_setopt($ch,CURLOPT_URL,"http:
//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]."< br />";
echo $wd[1];
//关闭CURL
curl_close($ch);
?>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: