首頁 > 後端開發 > php教程 > php三種方式下載文件

php三種方式下載文件

小云云
發布: 2023-03-22 12:18:01
原創
41706 人瀏覽過
推薦手冊php完全自學手冊

#本文主要跟大家分享php三種方式下載文件,希望能幫助大家。

1、直接新增檔案連結

<button>
    <a href = "http://localhost/down.zip">
    下载文件</button>
登入後複製

點選該按鈕下載:
php三種方式下載文件

# #2、傳遞參數查找並跳到下載連結

傳遞參數:

<button>
    <a href = "http://localhost?f=&#39;down&#39;">
    下载文件
</button>
登入後複製

找到檔案並挑戰下載連結:

<?php$down = $_GET[&#39;f&#39;];   //获取文件参数$filename = $down.&#39;.zip&#39;; //获取文件名称$dir ="down/";  //相对于网站根目录的下载目录路径$down_host = $_SERVER[&#39;HTTP_HOST&#39;].&#39;/&#39;; //当前域名//判断如果文件存在,则跳转到下载路径if(file_exists(__DIR__.&#39;/&#39;.$dir.$filename)){
    header(&#39;location:http://&#39;.$down_host.$dir.$filename);
}else{
    header(&#39;HTTP/1.1 404 Not Found&#39;);
}
登入後複製

結果:

  • 檔案存在

php三種方式下載文件

  • #檔案不存在


    php三種方式下載文件

#3、head() 和fread()函數把檔案直接輸出到瀏覽器
<?php  
$file_name = "down";$file_name = "down.zip";     //下载文件名    $file_dir = "./down/";        //下载文件存放目录    //检查文件是否存在    if (! file_exists ( $file_dir . $file_name )) {    
    header(&#39;HTTP/1.1 404 NOT FOUND&#39;);  
} else {    
    //以只读和二进制模式打开文件   
    $file = fopen ( $file_dir . $file_name, "rb" ); 

    //告诉浏览器这是一个文件流格式的文件    
    Header ( "Content-type: application/octet-stream" ); 
    //请求范围的度量单位  
    Header ( "Accept-Ranges: bytes" );  
    //Content-Length是指定包含于请求或响应中数据的字节长度    
    Header ( "Accept-Length: " . filesize ( $file_dir . $file_name ) );  
    //用来告诉浏览器,文件是可以当做附件被下载,下载后的文件名称为$file_name该变量的值。
    Header ( "Content-Disposition: attachment; filename=" . $file_name );    

    //读取文件内容并直接输出到浏览器    
    echo fread ( $file, filesize ( $file_dir . $file_name ) );    
    fclose ( $file );    
    exit ();    
}
登入後複製

結果:和第二個一樣
總結:
第一個和第二個操作比較簡單,但是容易暴露文件的真實地址,安全性不高,第三種能夠較好的把文件的真實位址隱藏起來
相關文章推薦1.
PHP如何下載伺服器上的檔案
2.
PHP如何實現大檔案下載? (程式碼實例)###3.###PHP如何實作檔案下載斷點續傳#########相關影片推薦###:######1.獨孤九賤(4)_PHP影片教學#########

以上是php三種方式下載文件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板