文件上传 - 尼农小道
文件上传
文件上传就是将客户端的文件上传到服务器端(并不是简单的copy)
文件上传需要两部分:客户端、服务器端。
客户端:
- 利用form中的file表单元素进行文件上传
- 对于get方式只能传递文本性的信息,POST可以传递二进制数据
- enctype:主要用于设置数据传递的方式
- 取值:
- aplication/x-www-url-encoded (默认)主要用于传输文本性的数据。
- multipart/form-data 用于设置传多种表单数据(文本数据与二进制数据)
服务器端
- php.ini中需要开启文件上传:file_uploads
- php.ini中临时目录:upload_tmp_dir
- php.ini中控制上传文件大的:upload_maxfile_size
php文件上传的设置:
php.ini中有一个
file_uploads
示例:
upload_tmp_dir
用于设置文件上传的临时保存的目录,临时目录的特点:当脚本执行结束后,临时文件会被马上删除。
upload_max_filesize
用于设置php对上传文件大小的限制值
一上最多所能上传文件的限制
由于临时文件目录中会有脚本执行结束删除文件,那么需在脚本执行结束之前就将上传的文件,移动另的目录(专用于存储文件上传的目录)
move_uploaded_file($filename,$target);函数
说明:
$filename是文件名
$target是目录名(用户自定义的)
将$filename移动$dirname指定的目录
$_FIELS:主要用于记录文件上传的相关信息
封装文件上传函数
1、定义函数
2、由于需要根据表单元素的name属性值,在$_FILES数组中找到临时文件的完整文件名,还不能对前端的input表单元素的name属性值 限制死。需要后台通过array_keys动态获取到input表单元素的name属性值
示例:
代码:
第3步:获取临时文件名
第4步:获取文件后缀
第5步:封装随机生成文件名函数
第6步:调用生成文件名函数
第7步:移动文件
文件上传错误信息
主要保存在$_FILES['name属性值']['error']
示例:
error的值:
upload_err_ok 0表示没有错误,上传成功
upload_err_ ini_size 1
upload_err_form_size 2
示例:
upload_err_partial 3
upload_err_no_file 4
upload_err_no_tmp_dir 6
upload_err_cant_write 7
示例:
第8步:对错误信息判断
//判断文件上传是否成功
switch($arr[$v]['error']){
case 0:
$arrFiles['filename'][]=$fullname;
$arrFiles['code'][]=0;
break;
case 1:
$arrFiles['filename'][]=false;
$arrFiles['code'][]='超过php文件大小限制';
break;
case 2:
$arrFiles['filename'][]=false;
$arrFiles['code'][]='超过form表单文件大小限制';
break;
case 3:
$arrFiles['filename'][]=false;
$arrFiles['code'][]='网络原因部分上传';
break;
case 4:
$arrFiles['filename'][]=false;
$arrFiles['code'][]='没有选择文件';
break;
case 6:
$arrFiles['filename'][]=false;
$arrFiles['code'][]='没有临时目录';
break;
case 7:
$arrFiles['filename'][]=false;
$arrFiles['code'][]='目录没有写权限';
break;
}