当前位置: 首页 > 编程笔记 >

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

公羊渝
2023-03-14
本文向大家介绍php多个文件及图片上传实例详解,包括了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='myfile[]'><br>

选择文件2:<input type="file" name='myfile[]'><br>

选择文件3:<input type="file" name='myfile[]'><br>

<input type="submit" value="上传文件">

</form>

</body>

</html>

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

//打印三维数组$_FILES中的内容,查看一下存储上传文件的结构

print_r($_FILES);

?>

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

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))

)

通过输出$_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='file' name='filelist[]' size='50'/></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['HTTP_HOST'].$_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>

<!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='file' name='filelist[]' size='50'/></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['HTTP_HOST'].$_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>

提交文件代码
<!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('Ym')."/"; 

if (!is_dir($Path))//创建路径 

{ mkdir($Path); } 

echo "<div>"; 

for ($i=0;$i<count($filelist);$i++) 

{ //$_FILES["filelist"]["size"][$i]的排列顺序不可以变,因为fileist是一个二维数组 

if ($_FILES["filelist"]["size"][$i]!=0) 

{ 

$File=$Path.date('Ymdhm')."_".$_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 "</div><br><a href="$postadd" href="$postadd">返回</a></div>"; 

} 

?> 

</body> 

</html>

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

希望本文所述对大家的PHP程序设计有所帮助。

 类似资料:
  • 本文向大家介绍php判断文件上传图片格式的实例详解,包括了php判断文件上传图片格式的实例详解的使用技巧和注意事项,需要的朋友参考一下 php判断文件上传图片格式的实例详解 判断文件图片类型, 如上如果用户修改文件后缀为png jpeg等无法满足,查了查资料解决方法是采用判断文件的二进制流信息,如果你刚好遇到这种问题不妨尝试一下: 如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,

  • 本文向大家介绍PHP多文件上传实例,包括了PHP多文件上传实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP多文件上传的方法。分享给大家供大家参考。具体如下: 希望本文所述对大家的php程序设计有所帮助。

  • 本文向大家介绍PHP文件上传类实例详解,包括了PHP文件上传类实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP文件上传类。分享给大家供大家参考,具体如下: 这里演示了FileUpload.class.php文件上传类,其中用到了两个常量,可在网站配置文件中定义: 具体代码如下: 其中,用到了一个静态工具类 Tool.class.php,代码如下: Tool.class.php

  • 本文向大家介绍Angularjs上传图片实例详解,包括了Angularjs上传图片实例详解的使用技巧和注意事项,需要的朋友参考一下 •上传图片需要引入插件ngFileUpload,使用bower安装方法: bower install ng-file-upload --save,安装后需要在命名app的名字js文件中注入,如下所示: •在相应的html中引入文件路径:<script src="lib

  • 本文向大家介绍php+ajax实现图片文件上传功能实例,包括了php+ajax实现图片文件上传功能实例的使用技巧和注意事项,需要的朋友参考一下 目前常用的异步文件上传功能有几种,比较多见的如使用iframe框架形式,ajax功能效果,以及flash+php功能,下面介绍ajax与iframe实现异步文件上传的功能的例子。 方法一,利用jquery ajaxfileupload.js实现文件上传 其

  • 本文向大家介绍PHP多文件上传类实例,包括了PHP多文件上传类实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP多文件上传类。分享给大家供大家参考。具体如下: 希望本文所述对大家的php程序设计有所帮助。