使用file_get_contents()和curl()抓取网络资源的效率对比

在将小程序用户头像合成海报的时候,用到了抓取用户头像对应的网络资源,那么抓取方式有很多,比如 file_get_contents,curl等,如何抓取就成了问题,下面主要是对比这两种方式的效率快慢问题

1 echo '开始时间为:'.time().'<br>'; 2 $img_file = file_get_contents($user['avatarurl']);  //小程序传的头像是网络地址需要周转一下
3 $img_content_logo= base64_encode($img_file); 4 echo '结束时间为:'.time().'<br>';

结果为:

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。

开始时间为:1555490134

结束时间为:1555490150

不知道是不是服务器的问题,中间花费时间竟然高达16秒,多试几次,也是在这14、5秒之间,肯定是不行的

再看一下使用curl的(最后有封装的curl_file_get_contents()函数)

1 echo '开始时间为:'.time().'<br>'; 2 $img_file = curl_file_get_contents($user['avatarurl']);  //小程序传的头像是网络地址需要周转一下
3 $img_content_logo= base64_encode($img_file); 4 echo '结束时间为:'.time().'<br>';

结果为:

开始时间为:1555490335

结束时间为:1555490335

效率一下子就提升了,花费时间最多1秒,而且这只是粗略的计算,如果采用更严谨的计算花费时间的话,可能会更低

 1 function curl_file_get_contents($durl)  2 {  3     $ch = curl_init();  4     curl_setopt($ch, CURLOPT_URL, $durl);  5     curl_setopt($ch, CURLOPT_TIMEOUT, 5);  6     curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);  7     $r = curl_exec($ch);  8     curl_close($ch);  9     return $r; 10 }

 

扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄