abstrak:upload.html: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>上傳文件
upload.html: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>上傳文件</title> </head> <body> <form action="upload.php" method="post" enctype="multipart/form-data"> <input type="file" name="MyFile"> <input type="submit" value="上傳文件"> </form> </body> </html> 上傳操作: function.php: <?php /** * 單文件上傳操作 * @param $fileInfo 上傳的文件信息 * @param string $uploadPath 上傳的指定目錄 * @param array $allowExt 上傳的文件類型 * @param int $maxSize 上傳的文件最大值 * @return string 提示信息 */ function upload_file($fileInfo,$uploadPath='./upload',$allowExt=['png','jpg','jpeg','gif','txt','html'],$maxSize=10000000) { if ($fileInfo['error'] === 0){ $ext = strtolower(pathinfo($fileInfo['name'],PATHINFO_EXTENSION)); if (!in_array($ext,$allowExt)){ return '非法文件類型!'; } if ($fileInfo['size']>$maxSize){ return '超出文件上傳最大值!'; } if (!is_uploaded_file($fileInfo['tmp_name'])){ return '非法上傳!'; } if (!is_dir($uploadPath)){ mkdir($uploadPath,0777,true); } $uniName = md5(uniqid(microtime(true),true)).".".$ext; $dest = $uploadPath."/".$uniName; if (!move_uploaded_file($fileInfo['tmp_name'],$dest)){ return '文件上傳失敗!'; } return '文件上傳成功!'; }else{ switch ($fileInfo['error']){ case 1: $res = '上傳的文件超過了 php.ini 中 upload_max_filesize 選項限制的值!'; break; case 2: $res = '上傳文件的大小超過了 HTML 表單中 MAX_FILE_SIZE 選項指定的值!'; break; case 3: $res = '文件只有部分被上傳!'; break; case 4: $res = '沒有文件被上傳!'; break; case 6: $res = '找不到臨時文件夾!'; break; case 7: $res = '文件寫入失敗!'; } return $res; } } upload.php: <?php include 'function10.php'; $fileinfo = $_FILES['MyFile']; var_dump(upload_file($fileinfo)); 下載操作: function.php: <?php /* * 文件的下載 * @param $filename 下載的文件 */ function dow_file($filename) { //告訴瀏覽器返回文件的大小 header('Accept-Length:'.filesize($filename)); //告訴瀏覽器文件作為附件處理,并告訴瀏覽器下載完的文件名 header('Content-Disposition:attachment;filename='.basename($filename)); //輸出文件/下載文件 readfile($filename); } dow_file('www.zip');
Guru membetulkan:天蓬老師Masa pembetulan:2019-04-10 13:26:05
Rumusan guru:文件的上傳下載, 對于一些功能性站點來說, 非常重要, 文件上傳是用戶與服務(wù)交互的手段, 是外部數(shù)據(jù)的入口, 必須嚴(yán)格把控, 永遠不要相信你的用戶