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

最近需要获取别人网站上的音乐数据。用了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);  ?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值