上传文件的信息和数据,都保存在$\_FILFS全局数组中,不在$\_POST中,$\_POST是普通表单信息
![Image](https://box.kancloud.cn/f013478ec0e9a2d71ee83c3abd347298_448x166.png)
- name:原文件名称;
- type:上传文件的后缀名;
- tmp\_name:上传文件的二进制数据,在服务器端的保存位置。
- error:上传文件的错误编号。
- size:上传文件大小
#### 上传文件错误代码
第5个错误为上传文件大小为0
1为文件超过了php对上传文件大小的设置 upload\_max\_filesize
2为文件过大,超过表单中元素 MAX\_FILE\_SIZE
3文件没有上传完
4没有上传文件
6临时上传目录没找到 可以在ini中改;upload\_tmp\_dir=
7临时文件写入失败 磁盘空间不足,权限不允许
#### 判断文件是否通过HTTP POST上传的
语法:bool is\_upload\_file(string $filename) 参数:$filename是上传的临时文件
$filename就用的是$\_FILES\[‘uploadFile’\]\[‘tmp\_name’\]
#### 将上传文件移动到新位置
语法:bool move\_upload\_file(string $filename,string $destination);
参数: $filename临时文件 $destination目标文件,一般将目标文件复制到网站空间
#### 生成唯一ID文件名
语法:string uniqid(\[string $prefix=””\[,bool $more\_entropy = false\] \])
参数:如果省略2个参数则生成13位的随机数. $prefix给随机数添加前缀
$more\_entropy后面添加一个子随机数
#### 验证上传文件是否有错误
if($\_FILES\[‘uploadFile’\]\[‘error’\] != 0){exit(‘上传文件发生错误’);}
#### 上传文件大小判断
(1) 修改php.ini中的upload\_max\_filesize配置项(单个文件大小)系统默认上传文件大小为2M
(2) 在表单中使用隐藏域来存储文件的最大允许上传的值
提示:要写在之前才有效
如果超过php.ini中的max\_file\_size指定的最大值,则$\_FILES\[‘upload’\]\[‘error’\]=2
(3) 在服务器端也要进行大小判断
#### 使用php.fileinfo对MIME类型进行检查
在php.ini中开启extension=php\_fileinfo.dll
#### finfo\_file()
返回指定文件的信息(字符集,MIME类型)
语法:string finfo\_file(resource $finfo,string $file\_name=NULL);
参数:$finfo资源 $file\_name指定取出信息的文件名
#### finfo\_open()
创建一个检查MIME类型的资源
语法:resource finfo\_open(\[int $options=FILEINFO\_NONE\]);
参数:如果是默认参数,则返回含有字符集的MIME类型,如果使用FILEINFO\_MIME参数,只返回MIME类型。