• PHP下载文件的几种方案


    PHP下载远程文件的3种方法以及性能考虑
    2014-02-21      0 个评论      
    收藏    我要投稿

    今天在做导出Excel的时候,总是要测试导出的Excel文件,频繁的下载和打开,很麻烦

     
    就想着写段代码一气呵成  服务端导出Excel==>下载Excel文件到本地==>并打开的操作。
     
    这里摘出PHP下载远端文件的方案,以备忘。其中第3种方法考虑到文件过大时的性能问题。
     
     
     
     
     
    3种方案:
     
    -rw-rw-r-- 1 liuyuan liuyuan 470 Feb 20 18:12 test1_fopen.php
    -rw-rw-r-- 1 liuyuan liuyuan 541 Feb 20 18:06 test2_curl.php
    -rw-rw-r-- 1 liuyuan liuyuan 547 Feb 20 18:12 test3_curl_better.php
     
     
     
    方案1,适用于小文件
     
    直接使用fopen()/file_get_contents()获取文件流并用file_put_contents()写入
     
    <?php
        //an example xls file form baidu wenku
        $url = 'http://bs.baidu.com/wenku4/%2Fe43e6732eba84a316af36c5c67a7c6d6?sign=MBOT:y1jXjmMD4FchJHFHIGN4z:lfZAx1Nrf44aCyD6tJqJ2FhosLY%3D&time=1392893977&response-content-disposition=attachment;%20filename=%22php%BA%AF%CA%FD.xls%22&response-content-type=application%2foctet-stream';
     
        $fp_input = fopen($url, 'r');
        file_put_contents('./test.xls', $fp_input);
     
        exec("libreoffice ./test.xls", $out, $status);
    ?>
      
     
    方案2:通过Curl获取内容
     
     
    <?php
        //an example xls file form baidu wenku
        $url = 'http://bs.baidu.com/wenku4/%2Fe43e6732eba84a316af36c5c67a7c6d6?sign=MBOT:y1jXjmMD4FchJHFHIGN4z:lfZAx1Nrf44aCyD6tJqJ2FhosLY%3D&time=1392893977&response-content-disposition=attachment;%20filename=%22php%BA%AF%CA%FD.xls%22&response-content-type=application%2foctet-stream';
     
        $ch = curl_init($url);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        file_put_contents('./test.xls', curl_exec($ch));
        curl_close($ch);
     
        exec("libreoffice ./test.xls", $out, $status);
    ?>
      
     
    第1,2种方案存在一个问题,就是在写入本地磁盘之前,文件会被读入内存中,那么当文件很大的时候,可能会超出内存而崩溃
     
    即使你的内存设置的足够的大,那这也是不别要的开销
     
    解决方法是:直接给CURL一个可写的文件流来让它自己来解决这个问题(通过 CURLOPT_FILE选项),这样就要先创建一个文件指针给它。
     
     
    <?php
        //an example xls file form baidu wenku
        $url = 'http://bs.baidu.com/wenku4/%2Fe43e6732eba84a316af36c5c67a7c6d6?sign=MBOT:y1jXjmMD4FchJHFHIGN4z:lfZAx1Nrf44aCyD6tJqJ2FhosLY%3D&time=1392893977&response-content-disposition=attachment;%20filename=%22php%BA%AF%CA%FD.xls%22&response-content-type=application%2foctet-stream';
     
        $fp_output = fopen('./test.xls', 'w');
        $ch = curl_init($url);
        curl_setopt($ch, CURLOPT_FILE, $fp_output);
        curl_exec($ch);
        curl_close($ch);
     
        exec("libreoffice ./test.xls", $out, $status);
    ?>
     
     
     
     
     
     
     
     
     
     
     
     
     
     
  • 相关阅读:
    Jquery.validate.js表单验证插件的使用
    UEditor编辑文章出现多余空行问题的解决办法
    jQuery问题:$XXX is not a function
    PHP+memcache扩展(集成环境wampserver环境下)
    Provider 错误 '80004005' 未指定的错误 /conn.asp,行 23
    PHP+MD5
    Mysql(Mariadb) 基础操作语句 (持续更新)
    什么是存储引擎以及不同存储引擎特点
    微信网页授权(OAuth2.0) PHP 源码简单实现
    字符集和字符集编码详解
  • 原文地址:https://www.cnblogs.com/caicaizi/p/5000589.html
Copyright © 2020-2023  润新知