武汉PHP培训
达内武汉民大中心

15827352908

热门课程

武汉PHP培训丨PHP多个文件及图片上传实例详解

  • 时间:2018-01-31 11:43
  • 发布:武汉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>

武汉PHP培训

    <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培训

马上预约七天免费试听课

姓名:

电话:

上一篇:武汉PHP培训丨一个高级PHP工程师所应该具备的
下一篇:武汉PHP培训丨字符串中的单引号与双引号的区别?

达内人力资源经理人课程上线 打造HR就业实操课程

2018年北京洪堡教育大会,达内教育集团总裁韩少云分享少儿编程

达内教育集团总裁韩少云:双师模式的实践与思考

达内与广西教育学院携手签约,共建专业开启校企合作新阶段!

选择城市和中心
贵州省

广西省

海南省

有位老师想和您聊一聊