在前一篇文章里讲到了关于PHP文件上传原理和简单操作举例是单文件上传。
http://www.cnblogs.com/lichenwei/p/3879566.html
其实多文件上传和单文件上传大同小异,原理都是一样的,只是在代码上做了点小技巧。
首先还是index.html上传表单,只是把之前上传文件表单里的file更改成了file[]
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"head> Meta http-equiv="Content-Type" content="text/html;charset=UTF-8"title>upload files</body> form action="upload.PHP" enctype="multipart/form-data" method="post"> input type="hidden" name="MAX_FILE_SIZE" value="100000" /> 上传文件:="file"="file[]"/><br/> ="submit"="上传" /> formhtml>
在upload.PHP用$_FILES打印看看
<?PHP
print_r($_FILES);
?>
得出下面多维数组
Array ( [file] => ( [name] => ( [0] => 照片1.jpg [1] => 照片2.jpg [2] => 照片3.jpg ) [type] => ( [0] => image/jpeg [1] => image/jpeg [2] => image/jpeg ) [tmp_name] => ( [0] => F:\wamp\tmp\PHP36C7.tmp [1] => F:\wamp\tmp\PHP36C8.tmp [2] => F:\wamp\tmp\PHP36C9.tmp ) [error] => ( [0] => 0 [1] => 0 [2] => 0 ) [size] => ) ) )
很明显我们需要得到一个关于文件信息的数组,数组里包含name,type,tmp_name,error,size,而此时我们得到的是个多维数组,虽然对应的键值都存在,但它是多维的,
我们只需要把它拆分,比如上面的3个文件,我们只需要把它拆分成对应的3个文件信息数组就行了。
拆分数组的结构
( [0] => ( [name] => 照片1.jpg [type] => image/jpeg [tmp_name] => F:\wamp\tmp\PHP13C1.tmp [error] => 0 [size] => 385150 ) [1] => ( [name] => 照片2.jpeg [tmp_name] => F:\wamp\tmp\PHP13D2. [size] => 242043 ) [2] => ( [name] => 照片3.jpeg [tmp_name] => F:\wamp\tmp\PHP13D3. [size] => 488293 ) )
下面是拆分重组数组代码
<?PHP //print_r($_FILES['file']); $arr=$_FILES['file']; $files=array(); for($i=0;$i<count($arr['name']);$i++){ $files[$i]['name']=$arr['name'][$i]; $i]['type']=$arr['type'][$i]['tmp_name']=$arr['tmp_name'][$i]['error']=$arr['error'][$i]['size']=$arr['size'][]; } print_r($files);
?>
剩下的东西就简单了,重复单文件上传的步骤,遍历处理一遍该数组就行了。
代码如下:
<?$i++){count()统计数组键值name长度 $files);){ 取得上传文件信息 $fileName=$i]['name'$fileType=$i]['type'$fileError=$fileSize=$i]['size'$tempName=$i]['tmp_name'];临时文件名 //定义上传文件类型 $typeList = array("image/jpeg","image/jpg","image/png","image/gif"); 定义允许的类型 if($fileError>0){ 上传文件错误编号判断 switch ($fileError) { case 1: $message="上传的文件超过了PHP.ini 中 upload_max_filesize 选项限制的值。"; break; case 2: $message="上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。"case 3: $message="文件只有部分被上传。"case 4: $message="没有文件被上传。"; case 6: $message="找不到临时文件夹。"case 7: $message="文件写入失败"case 8: $message="由于PHP的扩展程序中断了文件上传"; } exit("文件上传失败:".$message); } if(!is_uploaded_file($tempName)){ 判断是否是POST上传过来的文件 exit("不是通过HTTP POST方式上传上来的"); }else{ in_array($fileType,$typeList)){ exit("上传的文件不是指定类型"); }{ getimagesize()){ 避免用户上传恶意文件,如把病毒文件扩展名改为图片格式 exit("上传的文件不是图片"); } } $fileSize>1000000){ 对特定表单的上传文件限制大小 exit("上传文件超出限制大小"); }{ 避免上传文件的中文名乱码 $fileName=iconv("UTF-8","GBK",1)">$fileName);把iconv抓取到的字符编码从utf-8转为gbk输出 str_replace(".",time().".",1)">在图片名称后加入时间戳,避免重名文件覆盖 if(move_uploaded_file($tempName,"uploads/".$fileName)){ echo "上传文件成功!"; }{ echo "上传文件失败"; } } } } ?>
效果如下:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。