Home > php教程 > php手册 > php多个文件及图片上传实例详解

php多个文件及图片上传实例详解

PHPz
Release: 2018-10-08 14:43:10
forward
1434 people have browsed it

这篇文章主要介绍了php多个文件及图片上传的方法,以实例形式详细叙述了多文件上传的原理与实现技巧,非常实用,需要的朋友可以参考下

本文实例讲述了php多个文件及图片上传的方法。分享给大家供大家参考。具体实现方法如下:

多个文件上传是在单文件上传的基础上利用遍历数组的方式进行遍历表单数组然后把文件一个个上传到服务器上了,下面就来看一个简单多个文件上传实例

多个文件上传和单独文件上传的处理方式是一样的,只需要在客户端多提供几个类型为“file”的输入表单,并指定不同的“name”属性值。例如,在下面的代码中,可以让用户同时选择三个本地文件一起上传给服务器,客户端的表单如下所示:

代码如下:

<html>
<head><title>多个文件上传表单</title></head>
<body>
<form action="mul_upload.php" method="post" enctype="multipart/form-data">
<input type="hidden" name="MAX_FILE_SIZE" value="1000000">
选择文件1:<input type="file" name=&#39;myfile[]&#39;><br>
选择文件2:<input type="file" name=&#39;myfile[]&#39;><br>
选择文件3:<input type="file" name=&#39;myfile[]&#39;><br>
<input type="submit" value="上传文件">
</form>
</body>
</html>
Copy after login

在上面的代码中,将三个文件类型的表单以数组的形式组织在一起。当上面的表单教给PHP的脚本文件mul_upload.php时,在服务器端同样使用全局数组$_FILES存储所有上述文件的信息,但$_FILES由二维数组已经转变为三维数组,这样就可以存储多个上传文件的信息。在脚本文件mul_upload.php中,使用print_r()函数将$_FILES数组中的内容输出,代码如下所示:

代码如下:

<?php
//打印三维数组$_FILES中的内容,查看一下存储上传文件的结构
print_r($_FILES);
?>
Copy after login

当选择三个本地文件提交后,输出结果如下所示

代码如下:

Array(
    [myfile]=>Array(
        [name]=>Array(              //$_FILES["myfile"]["name"]存储所有上传文件的内容
            [0]=>Rav.ini         //$_FILES["myfile"]["name"][0]第一个上传文件的名称
            [1]=>msgsocm.log     //$_FILES["myfile"]["name"][1]第二个上传文件的名称
            [2]=>NOTEPAD.EXE)        //$_FILES["myfile"]["name"][2]第三个上传文件的名称
        [type]=>Array(               //$_FILES["myfile"]["type"]存储所有上传文件的类型
            [0]=>application/octet-stream          //$_FILES["myfile"]["type"][0]第一个上传文件的类型
            [1]=>application/octet-stream          //$_FILES["myfile"]["type"][1]第二个上传文件的类型
            [2]=>application/octet-stream)         //$_FILES["myfile"]["type"][2]第三个上传文件的类型
        [tmp_name]=>Array(
            [0]=>C:/WINDOWS/Temp/phpAF.tmp
            [1]=>C:/WINDOWS/Temp/phpB0.tmp
            [2]=>C:/WINDOWS/Temp/phpB1.tmp)
        [error]=>Array(
            [0]=>0
            [1]=>0
            [2]=>0)
        [size]=>Array(
            [0]=>64
            [1]=>1350
            [2]=>66560))
)
Copy after login

通过输出$_FILES数组的值可以看到,处理多个文件的上传和单个文件上传时的情况一样的,只是$_FILES数组的结构形式略有不同。通过这种方式可以支持更多数量的文件上传。

例子如下:

代码如下:

<!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"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>文档上传</title> 
</head> 
<body> 
<script language="javascript"><!-- 
动态添加文件选择控件--> 
function AddRow() 
{ 
var eNewRow = tblData.insertRow(); 
for (var i=0;i<1;i++) 
{ 
var eNewCell = eNewRow.insertCell(); 
eNewCell.innerHTML = "<tr><td><input type=&#39;file&#39; name=&#39;filelist[]&#39; size=&#39;50&#39;/></td></tr>"; 
} 
} 
// --></script> 
<form name="myform" method="post" action="uploadfile.php" enctype="multipart/form-data" > 
<table id="tblData" width="400" border="0"> 
<!-- 将上传文件必须用post的方法和enctype="multipart/form-data" --> 
<!-- 将本页的网址传给uploadfile.php--> 
<input name="postadd" type="hidden" value="<?php echo "http://".$_SERVER[&#39;HTTP_HOST&#39;].$_SERVER["PHP_SELF"]; ?>" /> 
<tr><td>文件上传列表 
<input type="button" name="addfile" onclick="AddRow()" value="添加列表" /></td></tr> 
<!-- filelist[]必须是一个数组--> 
<tr><td><input type="file" name="filelist[]" size="50" /></td></tr> 
</table> 
<input type="submit" name="submitfile" value="提交文件" /> 
</form> 
</body> 
</html>
Copy after login

代码如下:

<!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"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>文档上传</title> 
</head> 
<body> 
<script language="javascript"><!-- 
动态添加文件选择控件--> 
function AddRow() 
{ 
var eNewRow = tblData.insertRow(); 
for (var i=0;i<1;i++) 
{ 
var eNewCell = eNewRow.insertCell(); 
eNewCell.innerHTML = "<tr><td><input type=&#39;file&#39; name=&#39;filelist[]&#39; size=&#39;50&#39;/></td></tr>"; 
} 
}
// --></script> 
<form name="myform" method="post" action="uploadfile.php" enctype="multipart/form-data" > 
<table id="tblData" width="400" border="0"> 
<!-- 将上传文件必须用post的方法和enctype="multipart/form-data" --> 
<!-- 将本页的网址传给uploadfile.php--> 
<input name="postadd" type="hidden" value="<?php echo "http://".$_SERVER[&#39;HTTP_HOST&#39;].$_SERVER["PHP_SELF"]; ?>" /> 
<tr><td>文件上传列表 
<input type="button" name="addfile" onclick="AddRow()" value="添加列表" /></td></tr> 
<!-- filelist[]必须是一个数组--> 
<tr><td><input type="file" name="filelist[]" size="50" /></td></tr> 
</table> 
<input type="submit" name="submitfile" value="提交文件" /> 
</form> 
</body> 
</html>
Copy after login

提交文件代码

代码如下:

<!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"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>文件上传结果</title> 
</head> 
<body> 
<?php 
if ($_POST["submitfile"]!="") 
{ 
$Path="./".date(&#39;Ym&#39;)."/"; 
if (!is_dir($Path))//创建路径 
{ mkdir($Path); } 
echo "<p>"; 
for ($i=0;$i<count($filelist);$i++) 
{ //$_FILES["filelist"]["size"][$i]的排列顺序不可以变,因为fileist是一个二维数组 
if ($_FILES["filelist"]["size"][$i]!=0) 
{ 
$File=$Path.date(&#39;Ymdhm&#39;)."_".$_FILES["filelist"]["name"][$i]; 
if (move_uploaded_file($_FILES["filelist"]["tmp_name"][$i],$File)) 
{ echo "文件上传成功 文件类型:".$_FILES["filelist"]["type"][$i]." "."文件名:" 
.$_FILES["filelist"]["name"][$i]."<br>"; } 
else 
{ echo "文件名:".$_FILES["filelist"]["name"][$i]."上传失败</br>"; } 
} 
} 
echo "</p><br><a href="$postadd" href="$postadd">返回</a></p>"; 
} 
?> 
</body> 
</html>
Copy after login

上面例子基于 js来动态增加上传文件框了,从而达到多文件上传的功能。

更多相关教程请访问 php编程从入门到精通全套视频教程

 

Related labels:
source:jb51.net
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Recommendations
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template