<?php /** * @param $filePath //下载文件的路径 * @param int $readBuffer //分段下载 每次下载的字节数 默认1024bytes * @param array $allowExt //允许下载的文件类型 * @return void */ function downloadFile($filePath, $readBuffer = 1024, $allowExt = ['jpeg', 'jpg', 'peg', 'gif', 'zip', 'rar', 'txt']) { //检测下载文件是否存在 并且可读 if (!is_file($filePath) && !is_readable($filePath)) { return false; } //检测文件类型是否允许下载 $ext = strtolower(pathinfo($filePath, PATHINFO_EXTENSION)); if (!in_array($ext, $allowExt)) { return false; } //设置头信息 //声明浏览器输出的是字节流 header('Content-Type: application/octet-stream'); //声明浏览器返回大小是按字节进行计算 header('Accept-Ranges:bytes'); //告诉浏览器文件的总大小 $fileSize = filesize($filePath);//坑 filesize 如果超过2G 低版本php会返回负数 header('Content-Length:' . $fileSize); //注意是'Content-Length:' 非Accept-Length //声明下载文件的名称 header('Content-Disposition:attachment;filename=' . basename($filePath));//声明作为附件处理和下载后文件的名称 //获取文件内容 $handle = fopen($filePath, 'rb');//二进制文件用‘rb’模式读取 while (!feof($handle) ) { //循环到文件末尾 规定每次读取(向浏览器输出为$readBuffer设置的字节数) echo fread($handle, $readBuffer); } fclose($handle);//关闭文件句柄 exit; }
<?php // 允许上传的图片后缀 $allowedExts = array("gif", "jpeg", "jpg", "png"); $temp = explode(".", $_FILES["file"]["name"]); echo $_FILES["file"]["size"]; $extension = end($temp); // 获取文件后缀名 if ((($_FILES["file"]["type"] == "image/gif") || ($_FILES["file"]["type"] == "image/jpeg") || ($_FILES["file"]["type"] == "image/jpg") || ($_FILES["file"]["type"] == "image/pjpeg") || ($_FILES["file"]["type"] == "image/x-png") || ($_FILES["file"]["type"] == "image/png")) && ($_FILES["file"]["size"] < 204800) // 小于 200 kb && in_array($extension, $allowedExts)) { if ($_FILES["file"]["error"] > 0) { echo "错误:: " . $_FILES["file"]["error"] . "<br>"; } else { echo "上传文件名: " . $_FILES["file"]["name"] . "<br>"; echo "文件类型: " . $_FILES["file"]["type"] . "<br>"; echo "文件大小: " . ($_FILES["file"]["size"] / 1024) . " kB<br>"; echo "文件临时存储的位置: " . $_FILES["file"]["tmp_name"] . "<br>"; // 判断当前目录下的 upload 目录是否存在该文件 // 如果没有 upload 目录,你需要创建它,upload 目录权限为 777 if (file_exists("upload/" . $_FILES["file"]["name"])) { echo $_FILES["file"]["name"] . " 文件已经存在。 "; } else { // 如果 upload 目录不存在该文件则将文件上传到 upload 目录下 move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]); echo "文件存储在: " . "upload/" . $_FILES["file"]["name"]; } } } else { echo "非法的文件格式"; } ?>