比f(wàn)ile_get_contents穩(wěn)定的curl_get_contents分享
更新時(shí)間:2012年01月11日 21:47:21 作者:
相信使用過(guò)file_get_contents函數(shù)的朋友都知道,當(dāng)獲取的$url訪問(wèn)不了時(shí),會(huì)導(dǎo)致頁(yè)面漫長(zhǎng)的等待,甚至還能導(dǎo)致PHP進(jìn)程占用CPU達(dá)100%,因此這個(gè)函數(shù)就誕生了
分享一個(gè)實(shí)際在用的函數(shù):
/*比f(wàn)ile_get_contents穩(wěn)定的多!$timeout為超時(shí)時(shí)間,單位是秒,默認(rèn)為1s。*/
function curl_get_contents($url,$timeout=1) {
$curlHandle = curl_init();
curl_setopt( $curlHandle , CURLOPT_URL, $url );
curl_setopt( $curlHandle , CURLOPT_RETURNTRANSFER, 1 );
curl_setopt( $curlHandle , CURLOPT_TIMEOUT, $timeout );
$result = curl_exec( $curlHandle );
curl_close( $curlHandle );
return $result;
}
$hx = curl_get_contents('http://www.dhdzp.com');
相信使用過(guò)file_get_contents函數(shù)的朋友都知道,當(dāng)獲取的$url訪問(wèn)不了時(shí),會(huì)導(dǎo)致頁(yè)面漫長(zhǎng)的等待,甚至還能導(dǎo)致PHP進(jìn)程占用CPU達(dá)100%,因此這個(gè)函數(shù)就誕生了。curl的一些常識(shí)介紹
保留原file_get_contents函數(shù)的原因是當(dāng)讀取本地文件時(shí),用原生的file_get_contents顯然更合適。
另來(lái)自張宴的file_get_contnets的優(yōu)化,具體可看:http://www.dhdzp.com/article/28030.htm
同樣是設(shè)置超時(shí)時(shí)間來(lái)解決這個(gè)問(wèn)題。如果沒裝curl,就必須得用這個(gè)方式了。
$ctx = stream_context_create(array(
'http' => array(
'timeout' => 1 //設(shè)置一個(gè)超時(shí)時(shí)間,單位為秒
)
)
);
file_get_contents("http://www.dhdzp.com/", 0, $ctx);
另外,據(jù)不完全測(cè)試,使用curl獲取頁(yè)面比用file_get_contents穩(wěn)定的多。
復(fù)制代碼 代碼如下:
/*比f(wàn)ile_get_contents穩(wěn)定的多!$timeout為超時(shí)時(shí)間,單位是秒,默認(rèn)為1s。*/
function curl_get_contents($url,$timeout=1) {
$curlHandle = curl_init();
curl_setopt( $curlHandle , CURLOPT_URL, $url );
curl_setopt( $curlHandle , CURLOPT_RETURNTRANSFER, 1 );
curl_setopt( $curlHandle , CURLOPT_TIMEOUT, $timeout );
$result = curl_exec( $curlHandle );
curl_close( $curlHandle );
return $result;
}
$hx = curl_get_contents('http://www.dhdzp.com');
相信使用過(guò)file_get_contents函數(shù)的朋友都知道,當(dāng)獲取的$url訪問(wèn)不了時(shí),會(huì)導(dǎo)致頁(yè)面漫長(zhǎng)的等待,甚至還能導(dǎo)致PHP進(jìn)程占用CPU達(dá)100%,因此這個(gè)函數(shù)就誕生了。curl的一些常識(shí)介紹
保留原file_get_contents函數(shù)的原因是當(dāng)讀取本地文件時(shí),用原生的file_get_contents顯然更合適。
另來(lái)自張宴的file_get_contnets的優(yōu)化,具體可看:http://www.dhdzp.com/article/28030.htm
同樣是設(shè)置超時(shí)時(shí)間來(lái)解決這個(gè)問(wèn)題。如果沒裝curl,就必須得用這個(gè)方式了。
復(fù)制代碼 代碼如下:
$ctx = stream_context_create(array(
'http' => array(
'timeout' => 1 //設(shè)置一個(gè)超時(shí)時(shí)間,單位為秒
)
)
);
file_get_contents("http://www.dhdzp.com/", 0, $ctx);
另外,據(jù)不完全測(cè)試,使用curl獲取頁(yè)面比用file_get_contents穩(wěn)定的多。
您可能感興趣的文章:
- php基于curl重寫file_get_contents函數(shù)實(shí)例
- PHP CURL或file_get_contents獲取網(wǎng)頁(yè)標(biāo)題的代碼及兩者效率的穩(wěn)定性問(wèn)題
- php中file_get_contents與curl性能比較分析
- php采用file_get_contents代替使用curl實(shí)例
- 深入file_get_contents與curl函數(shù)的詳解
- 探討file_get_contents與curl效率及穩(wěn)定性的分析
- php中使用Curl、socket、file_get_contents三種方法POST提交數(shù)據(jù)
- PHP curl 或 file_get_contents 獲取需要授權(quán)頁(yè)面的方法
相關(guān)文章
thinkphp在模型中自動(dòng)完成session賦值示例代碼
今天在開發(fā)中遇到自動(dòng)完成中需要獲取session值然后自動(dòng)賦值的功能,還不錯(cuò),下面與大家分享下代碼2014-09-09
php獲取當(dāng)前月與上個(gè)月月初及月末時(shí)間戳的方法
這篇文章主要介紹了php獲取當(dāng)前月與上個(gè)月月初及月末時(shí)間戳的方法,涉及php針對(duì)日期與時(shí)間相關(guān)判斷與操作技巧,需要的朋友可以參考下2016-12-12
幾種有用的變型 PHP中循環(huán)語(yǔ)句的用法介紹
for語(yǔ)句可以說(shuō)是PHP(同時(shí)也是多種語(yǔ)言)的循環(huán)控制部份最基本的一個(gè)語(yǔ)句了,for語(yǔ)句的執(zhí)行規(guī)律和基礎(chǔ)用法在這里就不多說(shuō),可以參見PHP手冊(cè)for語(yǔ)句部分2012-01-01
遞歸刪除一個(gè)節(jié)點(diǎn)以及該節(jié)點(diǎn)下的所有節(jié)點(diǎn)示例
一段遞歸刪除一個(gè)部門以及它的所有子部門的一段代碼。僅供大家參考和自己以后備用2014-03-03
PHP實(shí)現(xiàn)動(dòng)態(tài)添加XML中數(shù)據(jù)的方法
這篇文章主要介紹了PHP實(shí)現(xiàn)動(dòng)態(tài)添加XML中數(shù)據(jù)的方法,結(jié)合實(shí)例形式分析了php操作xml格式數(shù)據(jù)類的定義及簡(jiǎn)單使用技巧,需要的朋友可以參考下2018-03-03
php結(jié)合curl實(shí)現(xiàn)多線程抓取
PHP利用 Curl可以完成各種傳送文件操作,比如模擬瀏覽器發(fā)送GET,POST請(qǐng)求等等,然而因?yàn)閜hp語(yǔ)言本身不支持多線程,所以開發(fā)爬蟲程序效率并不高,因此經(jīng)常需要借助Curl Multi Functions 這個(gè)功能實(shí)現(xiàn)并發(fā)多線程的訪問(wèn)多個(gè)url地址以實(shí)現(xiàn)并發(fā)多線程抓取網(wǎng)頁(yè)或者下載文件2015-07-07

