PHP實現文件下載
項目操做中不可避免要提供文件的下載,有時候要寫一些邏輯判斷或者提示啥,那下載的方法就須要作些調整。作個下載文件的集錦:javascript
-
readfile — 輸出文件 (手冊上有說明:讀入一個文件並寫入到輸出緩衝。)php
- <?php
- $file = 'monkey.gif' ;
-
- if ( file_exists ( $file )) {
- header ( 'Content-Description: File Transfer' );
- header ( 'Content-Type: application/octet-stream' );
- header ( 'Content-Disposition: attachment; filename=' . basename ( $file ));
- header ( 'Content-Transfer-Encoding: binary' );
- header ( 'Expires: 0' );
- header ( 'Cache-Control: must-revalidate' );
- header ( 'Pragma: public' );
- header ( 'Content-Length: ' . filesize ( $file ));
- ob_clean ();
- flush ();
- readfile ( $file );
- exit;
- }
- ?>
2.使用js實現文件下載,原理也是經過HTML5 a標籤設置download屬性就能實現。css
- <a href="./upload/user_excel/20161229.txt" download="20161229.txt"> 下 載 文 件 </a>
封裝的方法也就是使用實現上述a標籤的click事件。html
-
- function DownloadFileJs( $dir,$filename ){
- $url = $dir."/".$filename;
- $uploadjs = "<script type=\"text/javascript\" >
- var a = document.createElement('a');
- var url = \"".$url."\";
- var filename = '".$filename."';
- a.href = url;
- a.download = filename;
- a.click();window.URL.revokeObjectURL(url);
- console.log(a);
- </script>";
- echo ($uploadjs);
- exit;
-
- }
- ?>
-
調用測試以下:java
- $dir = './upload/user_excel';
- $filename = '20161229.txt';
- DownloadFileJs( $dir, $filename );
我的以爲此種方法比較靈活,固然也是相對而言,好比在進行excel導入,後臺在處理數據時須要反饋,彈出提示成功與否,再提供異常記錄(或操做記錄)的下載文件,使用js就比較易處理這個邏輯,而若使用第一種輸出緩衝的方法,PHP語句會優先處理解析,會跳過提示,用戶體驗就不太好 。此種方法也有缺陷,它須要HTML5的支持,只要不是太過舊的瀏覽器都是支持的。固然也有其餘的js方法下載,之後有機會會補充下去。web
三、依據瀏覽器跳轉文件地址,#非文本(txt、js、css、html…)直接可下載文件的特性。瀏覽器
- header("location:.'./upload/user.xls'");
- die;
此方法就比較靈活了,根據經驗很容易的選擇下載文件的方式。app
– 天行健,君子以自強不息!測試