上传部分
<?php
/**
* PHP多文件上传模块
*
* 用到的函数:is_upload_file(), move_upload_file(), pathinfo(), file_exists()
*/
//1.获取要上传文件的信息
$up_info = @$_FILES['myfile'];
$to_path = "./pic";
$typelist = array("image/gif","image/jpeg", "image/pjpeg", "image/png");
//在循环里面验证上传相关信息
for ($i = 0; $i < count($up_info['name']); $i++) {
//2.判断文件是否上传错误
if ($up_info['error'][$i]>0){
switch ($up_info['error'][$i]){
case 1:
$err_info="上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值";
break;
case 2:
$err_info="上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值";
break;
case 3:
$err_info="文件只有部分被上传";
break;
case 4:
$err_info="没有文件被上传";
break;
case 6:
$err_info="找不到临时文件夹";
break;
case 7:
$err_info="文件写入失败";
break;
default:
$err_info="未知的上传错误";
break;
}
continue($err_info);
}
//3.判断文件上传的类型是否合法
if (!in_array($up_info['type'][$i], $typelist)){
continue("文件类型错误!".$up_info['type'][$i]);
}
//4.上传文件的大小过滤
if ($up_info['size'][$i]>1000000){
continue("文件大小超过1000000");
}
//5.上传文件名处理
$exten_name = pathinfo($up_info['name'][$i], PATHINFO_EXTENSION);
do{
$main_name=date("YmdHis")."--".rand(100, 999);
$new_name = $main_name.".".$exten_name;
}while (file_exists($to_path.'/'.$new_name));
//6.判断是不是上传的文件,并执行上传
if (is_uploaded_file($up_info['tmp_name'][$i])){
if (move_uploaded_file($up_info['tmp_name'][$i], $to_path.'/'.$new_name)){
echo "文件上传成功!";
}else{
echo "文件移动失败!";
}
}
}
?>
下载部分
<?php
$filename = "20140723102400248.jpg";
header('Content-Type:image/jpeg');
header('Content-Disposition: attachment; filename="'.$filename.'"');
header('Content-Length:'.filesize($filename));
readfile($filename);
?>