>백엔드 개발 >PHP 튜토리얼 >PHP下载远程文件的3种方法以及性能考虑,_PHP教程

PHP下载远程文件的3种方法以及性能考虑,_PHP教程

WBOY
WBOY원래의
2016-07-12 09:02:23840검색

PHP下载远程文件的3种方法以及性能考虑,

今天在做导出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()写入

1 2 3 4 5 6 7 8 9 <?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获取内容

1 2 3 4 5 6 7 8 9 10 11 <?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选项),这样就要先创建一个文件指针给它。

1 2 3 4 5 6 7 8 9 10 11 12 <?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); ?>

  

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1085571.htmlTechArticlePHP下载远程文件的3种方法以及性能考虑, 今天在做导出Excel的时候,总是要测试导出的Excel文件,频繁的下载和打开,很麻烦 就想着写段代...
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.