分享一個實際在用的函數:
復制代碼 代碼如下:
/*比file_get_contents穩定的多!$timeout為超時時間,單位是秒,默認為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.jb51.net');
相信使用過file_get_contents函數的朋友都知道,當獲取的$url訪問不了時,會導致頁面漫長的等待,甚至還能導致PHP進程占用CPU達100%,因此這個函數就誕生了。curl的一些常識介紹
保留原file_get_contents函數的原因是當讀取本地文件時,用原生的file_get_contents顯然更合適。
另來自張宴的file_get_contnets的優化,具體可看:http://www.jb51.net/article/28030.htm
同樣是設置超時時間來解決這個問題。如果沒裝curl,就必須得用這個方式了。
復制代碼 代碼如下:
$ctx = stream_context_create(array(
'http' => array(
'timeout' => 1 //設置一個超時時間,單位為秒
)
)
);
file_get_contents("http://www.jb51.net/", 0, $ctx);
另外,據不完全測試,使用curl獲取頁面比用file_get_contents穩定的多。