zoukankan      html  css  js  c++  java
  • 使用file_get_contents()和curl()抓取网络资源的效率对比

    使用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>';

    结果为:

    开始时间为: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 }
  • 相关阅读:
    python 20 规范化目录
    python 19 包、logging模块
    python 17 Json、os、sys、hashlib等内置模块
    python 16 time、datetime、random模块
    python 15 带参装饰器
    python 14 装饰器
    [LeetCode]36. Compare Version Numbers版本号比较
    [LeetCode]35. Valid Parentheses有效括号
    [LeetCode]34. Add Binary二进制相加
    [LeetCode]33. Longest Palindromic Substring最长回文子串
  • 原文地址:https://www.cnblogs.com/cyfblogs/p/10724539.html
Copyright © 2011-2022 走看看