从性能方面考虑PHP下载远程文件的3种方法


Posted in PHP onDecember 29, 2015

今天在做导出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);
?>

 以上内容给大家介绍了从性能方面考虑PHP下载远程文件的3种方法,希望大家喜欢。

PHP 相关文章推荐
VML绘图板②脚本--VMLgraph.js、XMLtool.js
Oct 09 PHP
PHP脚本数据库功能详解(上)
Oct 09 PHP
整合了前面的PHP数据库连接类~~做成一个分页类!
Nov 25 PHP
function.inc.php超越php
Dec 09 PHP
两个强悍的php 图像处理类1
Jun 15 PHP
php5.3 废弃函数小结
May 16 PHP
php简单socket服务器客户端代码实例
May 18 PHP
php+mysql实现简单的增删改查功能
Jul 13 PHP
php导出生成word的方法
Dec 25 PHP
PHP7扩展开发之hello word实现方法详解
Jan 15 PHP
小程序微信支付功能配置方法示例详解【基于thinkPHP】
May 05 PHP
laravel实现上传图片,并且制作缩略图,按照日期存放的代码
Oct 16 PHP
Yii快速入门经典教程
Dec 28 #PHP
WordPress主题制作之模板文件的引入方法
Dec 28 #PHP
WordPress的主题编写中获取头部模板和底部模板
Dec 28 #PHP
YiiFramework入门知识点总结(图文教程)
Dec 28 #PHP
讲解WordPress中用于获取评论模板和搜索表单的PHP函数
Dec 28 #PHP
Yii实现单用户博客系统文章详情页插入评论表单的方法
Dec 28 #PHP
YII使用url组件美化管理的方法
Dec 28 #PHP
You might like
Apache, PHP在Windows 9x/NT下的安装与配置 (一)
2006/10/09 PHP
function.inc.php超越php
2006/12/09 PHP
php FPDF类库应用实现代码
2009/03/20 PHP
php 数学运算验证码实现代码
2009/10/11 PHP
mongo Table类文件 获取MongoCursor(游标)的实现方法分析
2013/07/01 PHP
浅析linux下apache服务器的配置和管理
2013/08/10 PHP
firefox和IE系列的相关区别整理 以备后用
2009/12/28 Javascript
jQuery实现设置、移除文本框默认值功能
2015/01/13 Javascript
js实现当鼠标移到表格上时显示这一格全部内容的代码
2016/06/12 Javascript
jQuery插件扩展extend的简单实现原理
2016/06/24 Javascript
js给table赋值的实例代码
2016/10/13 Javascript
Bootstrap模态框插件使用详解
2017/05/11 Javascript
nodejs搭建本地服务器轻松解决跨域问题
2018/03/21 NodeJs
详解Webpack + ES6 最新环境搭建与配置
2018/06/04 Javascript
Angular中使用ng-zorro图标库部分图标不能正常显示问题
2019/04/22 Javascript
QML实现圆环颜色选择器
2019/09/25 Javascript
从零学Python之引用和类属性的初步理解
2014/05/15 Python
Flask框架学习笔记(一)安装篇(windows安装与centos安装)
2014/06/25 Python
9种python web 程序的部署方式小结
2014/06/30 Python
python中Matplotlib实现绘制3D图的示例代码
2017/09/04 Python
Python GUI编程 文本弹窗的实例
2019/06/11 Python
django mysql数据库及图片上传接口详解
2019/07/18 Python
Pycharm-community-2020.2.3 社区版安装教程图文详解
2020/12/08 Python
详解java调用python的几种用法(看这篇就够了)
2020/12/10 Python
让IE下支持Html5的placeholder属性的插件
2014/09/02 HTML / CSS
英国儿童家具专卖店:GLTC
2016/09/24 全球购物
国贸专业个人求职信范文
2014/01/08 职场文书
文员岗位职责范本
2014/03/08 职场文书
产品质量承诺书
2014/03/27 职场文书
艺术设计专业个人求职信
2014/04/10 职场文书
取保候审保证书
2014/04/30 职场文书
工会优秀工作者事迹
2014/08/17 职场文书
车间主任岗位职责
2015/02/03 职场文书
2016继续教育研修日志
2015/11/13 职场文书
详解CSS玩转图片Base64编码
2021/05/25 HTML / CSS
GO中sync包自由控制并发示例详解
2022/08/05 Golang