在前一篇文章里讲到了关于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</title>
</head>
<body> <form action="upload.php" enctype="multipart/form-data" method="post">
<input type="hidden" name="MAX_FILE_SIZE" value="100000" />
上传文件:<input type="file" name="file[]"/><br/>
上传文件:<input type="file" name="file[]"/><br/>
上传文件:<input type="file" name="file[]"/><br/>
<input type="submit" value="上传" />
</form>
</body>
</html>

在upload.php用$_FILES打印看看

<?php  
  print_r($_FILES);
?>

得出下面多维数组

Array
(
[file] => Array
(
[name] => Array
(
[0] => 照片1.jpg
[1] => 照片2.jpg
[2] => 照片3.jpg
) [type] => Array
(
[0] => image/jpeg
[1] => image/jpeg
[2] => image/jpeg
) [tmp_name] => Array
(
[0] => F:\wamp\tmp\php36C7.tmp
[1] => F:\wamp\tmp\php36C8.tmp
[2] => F:\wamp\tmp\php36C9.tmp
) [error] => Array
(
[0] => 0
[1] => 0
[2] => 0
) [size] => Array
(
[0] => 0
[1] => 0
[2] => 0
) ) )

按照单文件上传的原理,先想想我们需要得到什么?

很明显我们需要得到一个关于文件信息的数组,数组里包含name,type,tmp_name,error,size,而此时我们得到的是个多维数组,虽然对应的键值都存在,但它是多维的,

我们只需要把它拆分,比如上面的3个文件,我们只需要把它拆分成对应的3个文件信息数组就行了。

拆分数组的结构

Array
(
[0] => Array
(
[name] => 照片1.jpg
[type] => image/jpeg
[tmp_name] => F:\wamp\tmp\php13C1.tmp
[error] => 0
[size] => 385150
) [1] => Array
(
[name] => 照片2.jpg
[type] => image/jpeg
[tmp_name] => F:\wamp\tmp\php13D2.tmp
[error] => 0
[size] => 242043
) [2] => Array
(
[name] => 照片3.jpg
[type] => image/jpeg
[tmp_name] => F:\wamp\tmp\php13D3.tmp
[error] => 0
[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];
$files[$i]['type']=$arr['type'][$i];
$files[$i]['tmp_name']=$arr['tmp_name'][$i];
$files[$i]['error']=$arr['error'][$i];
$files[$i]['size']=$arr['size'][$i];
} print_r($files);
?>

剩下的东西就简单了,重复单文件上传的步骤,遍历处理一遍该数组就行了。

代码如下:

<?php

    //print_r($_FILES['file']);
$arr=$_FILES['file'];
$files=array();
for($i=0;$i<count($arr['name']);$i++){//count()统计数组键值name长度
$files[$i]['name']=$arr['name'][$i];
$files[$i]['type']=$arr['type'][$i];
$files[$i]['tmp_name']=$arr['tmp_name'][$i];
$files[$i]['error']=$arr['error'][$i];
$files[$i]['size']=$arr['size'][$i];
} for($i=0;$i<count($files);$i++){
//取得上传文件信息
$fileName=$files[$i]['name'];
$fileType=$files[$i]['type'];
$fileError=$files[$i]['type'];
$fileSize=$files[$i]['size'];
$tempName=$files[$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 选项指定的值。";
break;
case 3:
$message="文件只有部分被上传。";
break;
case 4:
$message="没有文件被上传。";
break;
case 6:
$message="找不到临时文件夹。";
break;
case 7:
$message="文件写入失败";
break;
case 8:
$message="由于PHP的扩展程序中断了文件上传";
break;
} exit("文件上传失败:".$message); }
if(!is_uploaded_file($tempName)){
//判断是否是POST上传过来的文件
exit("不是通过HTTP POST方式上传上来的");
}else{
if(!in_array($fileType, $typeList)){
exit("上传的文件不是指定类型");
}else{
if(!getimagesize($tempName)){
//避免用户上传恶意文件,如把病毒文件扩展名改为图片格式
exit("上传的文件不是图片");
}
}
if($fileSize>1000000){
//对特定表单的上传文件限制大小
exit("上传文件超出限制大小");
}else{
//避免上传文件的中文名乱码
$fileName=iconv("UTF-8", "GBK", $fileName);//把iconv抓取到的字符编码从utf-8转为gbk输出
$fileName=str_replace(".", time().".", $fileName);//在图片名称后加入时间戳,避免重名文件覆盖
if(move_uploaded_file($tempName, "uploads/".$fileName)){
echo "上传文件成功!";
}else{
echo "上传文件失败";
}
} } }
?>

效果如下:

PHP多文件上传操作的更多相关文章

  1. python-web自动化-文件上传操作(非input标签的上传,需要借助第三方工具)

    文件上传操作 一.文件上传分两种情况:1. 如果是input可以直接输入路径的,可以直接调send_keys输入路径 2. 非input标签的上传,需要借助第三方工具:    2.1 Autolt 需 ...

  2. ui自动化chrome文件上传操作

    web自动化,再chrome浏览器中文件上传操作

  3. jsp 文件上传操作

    文件上传 1:完成一个文件上传的功能 index.jsp 注意更换form表单的enctype enctype就是encodetype就是编码类型的意思. multipart/form-data是指表 ...

  4. python - web自动化测试 - 文件上传操作

    # 12. 上传操作## (1)如果是input可以直接输入路径的,直接使用send_keys输入路径# (2)非input标签的,需要借助第三方工具:# A. AutoIt : 调用其生成的au3或 ...

  5. 基于python的selenium两种文件上传操作

    方法一.input标签上传     如果是input标签,可以直接输入路径,那么可以直接调用send_keys输入路径,这里不做过多赘述,前文有相关操作方法. 方法二.非input标签上传 这种上传方 ...

  6. Layer文件上传操作

    1:upload.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...

  7. SVN库文件上传操作步骤

    SVN库文件上传步骤: 1,sv st  或 svn status  查看本地库与远程库的差别(M代表文件有修改,?代表目录中有文件本地新增加) 2,根据1步骤中的查看结果:svn diff  差异文 ...

  8. 彻底搞懂HTML5文件上传操作需要的相关资料

    https://developer.mozilla.org/zh-CN/docs/Web/GuideMDN Web Guide https://developer.mozilla.org/zh-CN/ ...

  9. web自动化之文件上传操作

    #!/usr/bin/python3 # -*- coding: utf-8 -*- #Author: xiaojian #Time: 2018/11/16 20:49 import win32gui ...

随机推荐

  1. How To Install Java with Apt-Get on Ubuntu 16.04

    Introduction Java and the JVM (Java's virtual machine) are widely used and required for many kinds o ...

  2. Android开发(六)——组件颜色Selector(Selector与Shape的基本用法 )

    andorid控件改变状态时改变颜色,使用selector. <?xml version="1.0" encoding="utf-8" ?> < ...

  3. 5. EM算法-高斯混合模型GMM+Lasso

    1. EM算法-数学基础 2. EM算法-原理详解 3. EM算法-高斯混合模型GMM 4. EM算法-GMM代码实现 5. EM算法-高斯混合模型+Lasso 1. 前言 前面几篇博文对EM算法和G ...

  4. 3. 支持向量机(SVM)拉格朗日对偶性(KKT)

    1. 感知机原理(Perceptron) 2. 感知机(Perceptron)基本形式和对偶形式实现 3. 支持向量机(SVM)拉格朗日对偶性(KKT) 4. 支持向量机(SVM)原理 5. 支持向量 ...

  5. jQuery实现radio第一次点击选中第二次点击取消功能(转)

    转载自:http://www.jb51.net/article/113730.htm 由于项目的需求,要求radio点击两次后为取消状态,不方便修改为checkbox,可以用正面的方法实现. // j ...

  6. bash里wget失败

    直接使用wget是可以的,然而在shell脚本里却不行,后来发现原来是换行符的问题,编辑器默认的是\r\n,一不留神,自己把自己坑了

  7. elasticsearch golang的sdk使用

    文档第一 <elasticsearch权威指南>直接看官网在线版的,比较新,网上那些pdf版的,都是2.x版的,许多不兼容 官方API手册,可以选择版本. golang sdk库的选择 主 ...

  8. ORA-12705 解决方法

    问题:创建Oracle数据库出现ORA-12705:Cannot access NLS data files or invalid environment specified. 环境:重置系统,无Or ...

  9. 微软开放了.NET 4.5.1的源代码

    您目前处于: InfoQ首页 新闻 微软开放了.NET 4.5.1的源代码   微软开放了.NET 4.5.1的源代码 作者 姚琪琳 发布于 二月 26, 2014 | 1 讨论 新浪微博腾讯微博豆瓣 ...

  10. 基于Cookie的购物车

    var Cookies = {}; Cookies.set = function (name, value) { var argv = arguments; var argc = arguments. ...