比file_get_contents稳定的curl_get_contents分享

前端之家收集整理的这篇文章主要介绍了比file_get_contents稳定的curl_get_contents分享前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

分享一个实际在用的函数
<div class="codetitle"><a style="CURSOR: pointer" data="72390" class="copybut" id="copybut72390" onclick="doCopy('code72390')"> 代码如下:

<div class="codebody" id="code72390">
/比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('//www.jb51.cc');

相信使用过file_get_contents函数的朋友都知道,当获取的$url访问不了时,会导致页面漫长的等待,甚至还能导致PHP进程占用cpu达100%,因此这个函数就诞生了。curl的一些常识介绍
保留原file_get_contents函数的原因是当读取本地文件时,用原生的file_get_contents显然更合适。
另来自张宴的file_get_contnets的优化,具体可看://www.jb51.cc/article/28030.htm
同样是设置超时时间来解决这个问题。如果没装curl,就必须得用这个方式了。
<div class="codetitle"><a style="CURSOR: pointer" data="64104" class="copybut" id="copybut64104" onclick="doCopy('code64104')"> 代码如下:
<div class="codebody" id="code64104">
$ctx = stream_context_create(array(
'http' => array(
'timeout' => 1 //设置一个超时时间,单位为秒
)
)
);
file_get_contents("//www.jb51.cc/",$ctx);

另外,据不完全测试,使用curl获取页面比用file_get_contents稳定的多。

猜你在找的PHP相关文章