内容整理自网上!
一、$_FILES预定义变量解析
name:上传文件的名称
type:上传文件的MIME类型
tmp_name:上传到服务器上的临时文件名
size:上传文件的大小
error:上传文件的错误号
二、服务端配置
file_uploads = On
upload_tmp_dir =”临时文件保存目录”
upload_max_filesize = 2M 允许文件上传的最大值
max_file_uploads = 20 允许一次上传的最大文件数
post_max_size = 8M POST方式发送数据的最大值
max_execution_time = 120 设置了脚本被解析器终止之前允许的最大执行时间,单位为秒,防止程序写得不好而占尽服务器资源
max_input_time = 60 脚本解析输入数据允许的最大时间,单位是秒
max_input_nesting_level = 64 设置输入变量的嵌套深度
内存限制:
max_input_vars = 2500 接受多少输入的变量(限制分别应用于
GET、
_POST、和$_COOKIE超全局变量)指令的使用减轻了以哈希碰撞来进行拒绝服务攻击的可能性。如有超过指定指令数量的变量。将会导致E_WANING的产生,更多的输入变量将会从请求中截断。
memory_limit = 128M 最大单线程的独立内存使用量,也就是一个web请求,给予线程最大的内存使用量的定义。
三、客户端限制
客户端限制可以轻易更改,没什么作用!
四、错误信息说明
UPLOAD_ERR_OK:其值为0,没有错误发生,文件上传成功
UPLOAD_ERR_INI_SIZE:其值为1.上传文件超过了php.ini中upload_max_filesize选项限制的值
UPLOAD_ERR_FROM_SIZE:其值为2,上传文件的大小超过了HTML表单中MAX_FILE_SIZE选项指定的值
UPLOAD_ERR_PARTIAL:其值为3,文件只有部分被上传
UPLOAD_ERR_NO_FILE:其值为4,没有文件被上传
UPLOAD_ERR_NO_TMP_DIR:其值为6,找不到临时文件夹
UPLOAD_ERR_CANT_WRITE:其值为7,文件写入失败
UPLOAD_ERR_EXTENSION:其值为8,上传的文件被PHP扩展程序中断
五、代码
1、单文件上传
html:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Upload</title>
</head>
<body>
<form action="index.php" method="post" enctype="multipart/form-data">
请选择你要上传的文件:
<input type="file" name="myFile">
<input type="submit" value="upload">
</form>
</body>
</html>
单文件上传方法:
<?php
/*
* 单文件上传
* 参数:
* (String)$fileInfo:上传文件信息
* (String)$path:文件存放目录
* (Int)$maxSize:允许上传的文件最大大小,默认为2M
* (Array)$allowExt:允许上传的文件扩展名
* (String)$flag:是否检测上传文件是否为真实的图片类型,默认不检测
*/
function upload_single($fileInfo,$path='uploads/',$maxSize=2097152,$allowExt=null,$flag=false){
$destination=''; //上传后新的路径名
$data=[
'destination'=>$destination
];
//判断错误号
if ($fileInfo['error']==0){
//限制文件大小
if ($fileInfo['size']>$maxSize){
$data['msg']='上传文件过大';
return $data;
}
//判断上传文件的类型
$ext=strtolower(pathinfo($fileInfo['name'],PATHINFO_EXTENSION));
if ($allowExt){
if (!in_array($ext,$allowExt)){
$data['msg']='非法文件类型';
return $data;
}
}
//检测文件是否通过HTTP POST方法上传
if (!is_uploaded_file($fileInfo['tmp_name'])){
$data['msg']='文件不是通过HTTP POST方式上传';
return $data;
}
//检测是否为真实的图片类型,不能单纯靠扩展名
if($flag){
if (!getimagesize($fileInfo['tmp_name'])){
$data['msg']='不是真正的图片类型';
return $data;
}
}
//指定目录不存在时
if (!file_exists($path)){
mkdir($path,0777,true);
chmod($path,0777);
}
//防止文件名重名
$uniName=md5(uniqid(microtime(true),true));
$destination=$path.'/'.$uniName.'.'.$ext;
if (move_uploaded_file($fileInfo['tmp_name'],$destination)){
$data['msg']='文件传输成功';
$data['destination']=$destination;
return $data;
}else{
$data['msg']='文件移动失败';
return $data;
}
}else{
switch ($fileInfo['error']){
case 1:
$msg= '上传文件超过了PHP配置文件中的upload_max_filesize选项的值';
break;
case 2:
$msg= '超过了表单MAX_FILE_SIZE限制的大小';
break;
case 3:
$msg= '文件部分被上传';
break;
case 4:
$msg= '没有选择上传文件';
break;
case 6:
$msg= '没有找到临时目录';
break;
case 7:
$msg= '文件写入失败';
break;
case 8:
$msg= '系统错误';
break;
}
$data['msg']=$msg;
return $data;
}
}
引用:
<?php
header('content-type:text/html;charset=utf-8');
include_once 'upload.func.php';
$allowExt=array('jpeg','jpg','png','gif','wbmp');
$fileInfo=$_FILES['myFile'];
$flag=true;
$data=upload_single($fileInfo,'uploads/', 2097152,$allowExt,$flag);
echo $data['msg'];
2、多文件上传
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Upload</title>
</head>
<body>
<form action="index.php" method="post" enctype="multipart/form-data">
请选择你要上传的文件:<input type="file" name="myFile1"><br/>
请选择你要上传的文件:<input type="file" name="myFile2"><br/>
请选择你要上传的文件:<input type="file" name="myFile3"><br/>
请选择你要上传的文件:<input type="file" name="myFile4"><br/>
<input type="submit" value="upload">
</form>
</body>
</html>
上传方法文件增加一个函数:
function getFiles(){
$i=0;
foreach ($_FILES as $file) {
if (is_string($file['name'])) {
$files[$i] = $file;
$i++;
} elseif (is_array($file['name'])) {
foreach ($file['name'] as $key => $val) {
$files[$i]['name'] = $file['name'][$key];
$files[$i]['type'] = $file['type'][$key];
$files[$i]['tmp_name'] = $file['tmp_name'][$key];
$files[$i]['error'] = $file['error'][$key];
$files[$i]['size'] = $file['size'][$key];
$i++;
}
}
}
return $files;
}
引用:
<?php
header('content-type:text/html;charset=utf-8');
include_once 'upload.func.php';
$allowExt=array('jpeg','jpg','png','gif','wbmp');
$flag=true;
foreach ($_FILES as $fileInfo){
$data=upload_single($fileInfo,'uploads/', 2097152,$allowExt,$flag);
echo $data['msg'].'<br/>';
}
六、下载
html:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Upload</title>
</head>
<body>
<a href="index.php?filename=1.jpg" ><button value="">点击下载</button></a>
</body>
</html>
php:
<?php
$filename=$_GET['filename'];
header('content-disposition:attachment;filename='.basename($filename));
header('content-length:'.filesize($filename));
readfile($filename);