-
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程序设计有所帮助。
出处:http://www.phpfensi.com/php/20210425/14500.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式