PHP是一種流行的服務端程序語言,不僅可以用于動態網頁開發,還可用于處理文件上傳和下載。在本文中,我們將介紹如何使用PHP編寫文件下載腳本,并在不同場景下實現相應的下載功能。
最簡單的文件下載腳本就是讓用戶點擊超鏈接來下載文件。例如,你可以在頁面中插入以下HTML代碼:
<a href="download.php?file=example.pdf">點擊下載文件</a>
在這個例子中,超鏈接地址參數中指定了下載文件的文件名(example.pdf),這個值將被傳遞給名為“download.php”的腳本。要使下載操作起作用,我們需要在download.php中編寫一些PHP代碼,并發送必要的HTTP頭信息。以下是download.php文件的代碼:<?php
// 下載的文件
$file = $_GET['file'];
// 檢查文件是否存在
if (file_exists($file)) {
// 設置HTTP頭信息
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename="'.basename($file).'"');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
header('Content-Length: ' . filesize($file));
// 讀取文件內容并發送給用戶
readfile($file);
exit;
} else {
echo '文件不存在';
}
?>
當用戶點擊超鏈接時,download.php將被調用,判斷傳遞的文件名是否存在。如果存在,download.php將發送必要的HTTP頭信息,指示瀏覽器下載二進制文件。最后,download.php讀取文件內容,并發送給用戶。
這樣做的好處是非常簡單和直觀,但有一個明顯的缺點,就是用戶可以通過查看HTML源代碼,發現文件的真實下載地址。另外一個問題是,如果要下載的文件較大,服務器會花費大量時間和內存來讀取文件內容,這會影響性能。
為了解決這些問題,我們可以將文件放在服務器之外,通過PHP腳本下載文件。例如,我們可以將下載腳本放在/download/目錄下,而真正的文件則保存在/files/目錄下。使用這種方法,我們可以避免向用戶公開文件的真實位置。以下是/download/download.php文件的代碼:<?php
// 下載文件的目錄
$dir = '../files';
// 下載文件的名稱
$file = $_GET['file'];
// 文件路徑
$path = $dir . '/' . $file;
// 檢查文件是否存在
if (!file_exists($path)) {
die('文件不存在!');
}
// 文件類型
$type = mime_content_type($path);
// 文件大小
$size = filesize($path);
// 下載文件
header("Content-Disposition: attachment; filename=" . urlencode($file));
header("Content-Type: " . $type);
header("Content-Length: " . $size);
header("Content-Transfer-Encoding: binary");
readfile($path);
exit;
?>
在這個例子中,我們使用了mime_content_type()函數來獲取文件類型,并使用urlencode()函數來編碼文件名。使用這種方法,就不需要讀取整個文件的內容,在發送文件之前,只需將文件數據上傳到輸出緩沖區即可。
最后,需要注意的是,為了保證安全性,應該對文件名進行驗證,例如從白名單中選擇必要的文件擴展名,從而防止用戶下載或查看不安全的文件。上一篇php file協議
下一篇php file保存