簡(jiǎn)體 | Eng
          收藏夾
          -> -> -> - >
          [知識(shí)庫(kù)]主題: Php讀取網(wǎng)絡(luò)文件 Curl, ...   發(fā)布者: phpsir
          05/29/2013
          Visit:128 ,Today:1

          Php讀取網(wǎng)絡(luò)文件 Curl, Fsockopen ,file_get_contents 幾個(gè)方法的效率對(duì)比

          curl效率及穩(wěn)定原來(lái)可以遠(yuǎn)遠(yuǎn)超越file_get_contents

          至近需要獲取別人網(wǎng)站上的音樂(lè)數(shù)據(jù)。用了file_get_contents函數(shù),但是總是會(huì)遇到獲取失敗的問(wèn)題,盡管按照手冊(cè)中的 例子設(shè)置了超時(shí),可多數(shù)時(shí)候不會(huì)奏效:

          $config[\'context\'] = stream_context_create(array(‘http’ => array(‘method’ => “GET”,

          ’timeout’ => 5//這個(gè)超時(shí)時(shí)間不穩(wěn)定,經(jīng)常不奏效

          )

          ));

          這時(shí)候,看一下服務(wù)器的連接池,會(huì)發(fā)現(xiàn)一堆類似的錯(cuò)誤,讓我頭疼萬(wàn)分:

          file_get_contents(http://***): failed to open stream…

          現(xiàn)在改用了curl庫(kù),寫了一個(gè)函數(shù)替換:

          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;

          }

          如此,除了真正的網(wǎng)絡(luò)問(wèn)題外,沒(méi)再出現(xiàn)任何問(wèn)題。

          這是別人做過(guò)的關(guān)于curl和file_get_contents的測(cè)試:

          file_get_contents抓取google.com需用秒數(shù):

          2.31319094

          2.30374217

          2.21512604

          3.30553889

          2.30124092

          curl使用的時(shí)間:

          0.68719101

          0.64675593

          0.64326

          0.81983113

          0.63956594

          差距很大?呵呵,從我使用的經(jīng)驗(yàn)來(lái)說(shuō),這兩個(gè)工具不只是速度有差異,穩(wěn)定性也相差很大。

          建議對(duì)網(wǎng)絡(luò)數(shù)據(jù)抓取穩(wěn)定性要求比較高的朋友使用上面的 curl_file_get_contents函數(shù),不但穩(wěn)定速度快,還能假冒瀏覽器欺騙目標(biāo)地址哦!

          看到的其他文章收藏于此===============================

          php fsockopen

          方法1: 用file_get_contents 以get方式獲取內(nèi)容

          <?php

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

          $html = file_get_contents($url);

          echo $html;

          ?>

          方法2: 用fopen打開url, 以get方式獲取內(nèi)容

          <?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函數(shù),以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函數(shù)打開url,以get方式獲取完整的數(shù)據(jù),包括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函數(shù)打開url,以POST方式獲取完整的數(shù)據(jù),包括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庫(kù),使用curl庫(kù)之前,可能需要查看一下php.ini是否已經(jīng)打開了curl擴(kuò)展

          <?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 三個(gè)函數(shù) 都可以實(shí)現(xiàn)采集模擬發(fā)言 。 三者有什么區(qū)別,或者講究么

          趙永斌:

          有些時(shí)候用file_get_contents()調(diào)用外部文件,容易超時(shí)報(bào)錯(cuò)。換成curl后就可以.具體原因不清楚

          curl 效率比f(wàn)ile_get_contents()和fsockopen()高一些,原因是CURL會(huì)自動(dòng)對(duì)DNS信息進(jìn)行緩存(亮點(diǎn)啊 有我待親測(cè))

          范佳鵬:

          file_get_contents curl fsockopen

          在當(dāng)前所請(qǐng)求環(huán)境下選擇性操作,沒(méi)有一概而論:

          具我們公司開發(fā)KBI應(yīng)用來(lái)看:

          剛開始采用:file_get_contents

          后來(lái)采用:fsockopen

          至后到至今采用:curl

          (遠(yuǎn)程)我個(gè)人理解到的表述如下(不對(duì)請(qǐng)指出,不到位請(qǐng)補(bǔ)充)

          file_get_contents 需要php.ini里開啟allow_url_fopen,請(qǐng)求http時(shí),使用的是http_fopen_wrapper,不會(huì)keeplive.curl是可以的。

          file_get_contents()單個(gè)執(zhí)行效率高,返回沒(méi)有頭的信息。

          這個(gè)是讀取一般文件的時(shí)候并沒(méi)有什么問(wèn)題,但是在讀取遠(yuǎn)程問(wèn)題的時(shí)候就會(huì)出現(xiàn)問(wèn)題。

          如果是要打一個(gè)持續(xù)連接,多次請(qǐng)求多個(gè)頁(yè)面。那么file_get_contents和fopen就會(huì)出問(wèn)題。

          取得的內(nèi)容也可能會(huì)不對(duì)。所以做一些類似采集工作的時(shí)候,肯定就有問(wèn)題了。

          sock較底層,配置麻煩,不易操作。 返回完整信息。

          潘少寧-騰訊:

          file_get_contents 雖然可以獲得某URL的內(nèi)容,但不能post get啊。

          curl 則可以post和get啊。還可以獲得head信息

          而socket則更底層。可以設(shè)置基于UDP或是TCP協(xié)議去交互

          file_get_contents 和 curl 能干的,socket都能干。

          socket能干的,curl 就不一定能干了

          file_get_contents 更多的時(shí)候 只是去拉取數(shù)據(jù)。效率比較高 也比較簡(jiǎn)單。

          趙的情況這個(gè)我也遇到過(guò),我通過(guò)CURL設(shè)置host 就OK了。 這和網(wǎng)絡(luò)環(huán)境有關(guān)系

           
          最后更新: 2013-05-29 13:02:17
          • 聯(lián)系人信息

            分類目錄 - 電腦、軟件 - > 軟件設(shè)計(jì) - php讀取網(wǎng)絡(luò)文件 curl, fsockopen ,file_get_contents 幾個(gè)方法的效率對(duì)比

            姓名: phpsir
            電子信箱: phpsir@yahoo.cn
            手機(jī): N/A
            公司名稱: N/A
            聯(lián)系電話: N/A
            詳細(xì)地址: N/A
            郵政編碼: N/A
            網(wǎng)址URL:
            有效期:N/A
          • 評(píng)判這條信息 - 歡迎發(fā)表意見(jiàn)/建議 : Php讀取網(wǎng)絡(luò)文件 Curl, Fsockopen ,file_get_contents 幾個(gè)方法的效率對(duì)比

            * 必須填寫的信息

            優(yōu)秀信息 分類錯(cuò)誤 違禁信息 垃圾信息 過(guò)期 其它

            姓名: *
            詳細(xì)內(nèi)容: *
            聯(lián)系電話:
            詳細(xì)地址:
            郵政編碼:
            電子信箱:
            網(wǎng)址URL:
            管理密碼:*
            * 刪除/修改
            驗(yàn)證碼:*
            passcode

          搜索相關(guān): 電腦外設(shè) - 網(wǎng)絡(luò)設(shè)備、配件 - IC卡 - 網(wǎng)站建設(shè) - 服務(wù)器、工作站 - 插卡類 - UPS與電源 - MP3 - 軟件設(shè)計(jì) - 郵箱、網(wǎng)盤 - 信息技術(shù)合作 - 網(wǎng)絡(luò)工程 - 主機(jī)配件 - 二手設(shè)備 - 計(jì)算機(jī) - 安全、病毒防治 - 域名、虛擬主機(jī) - 軟件 - 消耗品 - 筆記本電腦 - 其他

          ©2025 孫悟空
          主站蜘蛛池模板: 99在线精品一区二区三区| 日本在线视频一区二区三区| 国产SUV精品一区二区88L| 无码精品国产一区二区三区免费| 福利一区二区在线| 日本免费一区二区在线观看| 精品无码成人片一区二区| 亚洲国产成人久久综合一区| 狠狠色婷婷久久一区二区| 国产一区二区三区露脸| 91在线精品亚洲一区二区| 岛国精品一区免费视频在线观看| 日韩精品久久一区二区三区| 精品一区二区三区| 一区二区在线观看视频| 亚洲国产国产综合一区首页| 亚洲乱码一区二区三区在线观看 | 国产激情一区二区三区 | 国产福利无码一区在线| 国产精品无码一区二区在线观 | 日韩视频在线一区| 免费无码A片一区二三区| 伊人久久精品无码麻豆一区| 精品国产一区二区三区不卡 | 国产精品视频一区麻豆| 亚洲色偷偷偷网站色偷一区| 精品欧洲av无码一区二区 | 成人精品视频一区二区三区| 亚洲AV无码一区二三区| 国产精品第一区第27页| 99精品国产一区二区三区| 中文字幕在线一区二区三区| 日韩精品无码一区二区三区四区| 激情内射日本一区二区三区| av无码人妻一区二区三区牛牛| 国产精品视频第一区二区三区| 在线观看午夜亚洲一区| 少妇无码AV无码一区| 亚洲国产老鸭窝一区二区三区| 亚洲国产一区国产亚洲| 无码人妻一区二区三区兔费|