下面我们就通过具体的代码示例,为大家介绍PHP实现多文件上传的一些简单方法。

第一种方法:利用单个文件上传方法

一段简单的form表单代码如下:

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <title>Title</title>

</head>

<body>

<form action="upload.php" method="post" enctype="multipart/form-data">

 选择文件进行上传: <input type="file" name="file1">

 选择文件进行上传: <input type="file" name="file2">

 选择文件进行上传: <input type="file" name="file3">

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

</form>

</body>

</html>

代码效果如下图:

如图我们选择上传了三个文件,然后我们再将文件上传给upload.php文件中,PHP代码如下:

<?php

echo "<pre>";

var_dump($_FILES);

那么我们继续通过浏览器访问结果如下:

这里我们得到了图中的二维数组,如果我们想要进行多文件上传就需要通过foreach循环来实现。

那么upload.php完整代码如下:

<?php

echo "<pre>";

var_dump($_FILES);

$files = [];

foreach ($_FILES as $fileInfo) {

    $files[] = upload_file($fileInfo);

}

var_dump($files);

function upload_file($fileInfo, $upload = "./upload", $imagesExt = ['gif', 'png', 'jpg'])

{

    if ($fileInfo['error'] === 0) {

        $ext = strtolower(pathinfo($fileInfo['name'], PATHINFO_EXTENSION));

        if (!in_array($ext, $imagesExt)) {

            return "文件非法类型";

        }

        if (!is_dir($upload)) {

            mkdir($upload, 0777, true);

        }

        $fileName = md5(uniqid(microtime(true), true)) . "." . $ext;

        $destName = $upload . "/" . $fileName;

        if (!move_uploaded_file($fileInfo['tmp_name'], $destName)) {

            return "文件上传失败!";

        }

        return "文件上传成功!";

    } else {

        switch ($fileInfo['error']) {

            case 1:

                echo '上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值';

                break;

            case 2:

                echo '上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值';

                break;

            case 3:

                echo '文件只有部分被上传';

                break;

            case 4:

                echo '没有文件被上传';

                break;

            case 6:

                echo '找不到临时文件夹';

                break;

            case 7:

                echo '文件写入失败';

                break;

        }

    }

}

最后我们选择多个文件上传,结果就如下图所示:

此时已经成功实现多个文件上传的操作了。

第二种方法:利用HTML5中的multiple方法

上传多文件的HTML界面的代码示例如下:

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <title>Title</title>

</head>

<body>

<form action="upload.php" method="post" enctype="multipart/form-data">

 选择文件进行上传: <input type="file" name="file[]" multiple=""><br>

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

</form>

</body>

</html>

此段代码效果如下图:

在这里的form表单中我们用到了HTML 5中的 multiple 属性,这个属性表示输入字段可选择多个值,也就是选择该属性时,此字段可以接受多个值。multiple是我们实现多文件上传的一个重要属性。同时我们将input中name名设置为一个file[] 数组。

那么我们再选择多个文件上传,如下图:

如图我们选择了三张图片,然后再用如下upload.php文件来接收三个数据。

upload.php代码示例如下:

<?php

echo "<pre>";

var_dump($_FILES);

$files = [];

foreach ($_FILES as $fileInfo) {

    $files[] = upload_file($fileInfo);

}

var_dump($files);

function upload_file($fileInfo, $upload = "./upload", $imagesExt = ['gif', 'png', 'jpg'])

{

    if ($fileInfo['error'] === 0) {

        $ext = strtolower(pathinfo($fileInfo['name'], PATHINFO_EXTENSION));

        if (!in_array($ext, $imagesExt)) {

            return "文件非法类型";

        }

        if (!is_dir($upload)) {

            mkdir($upload, 0777, true);

        }

        $fileName = md5(uniqid(microtime(true), true)) . "." . $ext;

        $destName = $upload . "/" . $fileName;

        if (!move_uploaded_file($fileInfo['tmp_name'], $destName)) {

            return "文件上传失败!";

        }

        return "文件上传成功!";

    } else {

        switch ($fileInfo['error']) {

            case 1:

                echo '上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值';

                break;

            case 2:

                echo '上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值';

                break;

            case 3:

                echo '文件只有部分被上传';

                break;

            case 4:

                echo '没有文件被上传';

                break;

            case 6:

                echo '找不到临时文件夹';

                break;

            case 7:

                echo '文件写入失败';

                break;

        }

    }

}

我们从图中可以看到,上传文件信息以三维数组形式展现,其中三个图片的名称、类型、临时存储的位置路径、大小等等信息都分别放在了一个数组中。

然而我们可以发现upload.php这个文件中的信息解析方法对于用multiple属性上传来的文件并没有产生效果。

那么本篇文章就先给大家介绍PHP使用multiple属性实现多文件上传的这两种简单方法,

PHP实现多文件上传的一些简单方法的更多相关文章

  1. Discuz!NT 后台任意文件上传的源代码修补方法

    相关的漏洞介绍: http://www.wooyun.org/bugs/wooyun-2013-035199 Discuz!NT 管理后台可以自定义文件类型,从而造成任意文件上传,测试过程中 aspx ...

  2. C#实现Web文件上传的两种方法

    1. C#实现Web文件的上传 在Web编程中,我们常需要把一些本地文件上传到Web服务器上,上传后,用户可以通过浏览器方便地浏览这些文件,应用十分广泛. 那么使用C#如何实现文件上传的功能呢?下面笔 ...

  3. IIS 之 通过 Web.config 修改文件上传大小限制设置方法

    在IIS 6.0中,不设置默认大小为4M,设置文件上传大小的方法,maxRequestLength(KB),executionTimeout(毫秒),配置如下节点: <system.web> ...

  4. PHP和Nginx 文件上传大小限制问题解决方法

    对于nginx+php的一些网站,上传文件大小会受到多个方面的限制,一个是nginx本身的限制,限制了客户端上传文件的大小,一个是php.ini文件中默认了多个地方的设置. 所以为了解决上传文件大小限 ...

  5. Django实现任意文件上传(最简单的方法)

    利用Django实现文件上传并且保存到指定路径下,其实并不困难,完全不需要用到django的forms,也不需要django的models,就可以实现,下面开始实现. 第一步:在模板文件中,创建一个f ...

  6. springMVC文件上传的三种方法

    这时:commonsmultipartresolver 的源码,可以研究一下 http://www.verysource.com/code/2337329_1/commonsmultipartreso ...

  7. 详解jQuery uploadify文件上传插件的使用方法

    uploadify这个插件是基于js里面的jquery库写的.结合了ajax和flash,实现了这个多线程上传的功能. 现在最新版为3.2.1. 在线实例 实例中用到的php文件UploaderDem ...

  8. SpringBoot从入门到精通十一(SpringBoot文件上传的两种方法)

    前言 在企业级项目开发过程中,上传文件是最常用到的功能.SpringBoot集成了SpringMVC,当然上传文件的方式跟SpringMVC没有什么出入. 本章目标 使用SpringBoot项目完成单 ...

  9. IIS 6和IIS 7 中设置文件上传大小限制设置方法,两者是不一样的

    在IIS 6.0中设置文件上传大小的方法,只要设置httpRuntime就可以了 <system.web> <httpRuntime executionTimeout="3 ...

随机推荐

  1. C++ 计算定积分、不定积分、蒙特卡洛积分法

    封装成了一个类,头文件和源文件如下: integral.h #pragma once //Microsoft Visual Studio 2015 Enterprise #include <io ...

  2. Python开发【第二章】:模块和运算符

    一.模块初识: Python有大量的模块,从而使得开发Python程序非常简洁.类库有包括三中: Python内部提供的模块 业内开源的模块 程序员自己开发的模块 1.Python内部提供一个 sys ...

  3. c# 事件 +=和-=有什么区别

    +=就是發生新事件的同時通知你: -=就是發生新事件的同時不通知你:

  4. Jquery DataTables 服务器后端分页 Ajax请求添加自定义参数.

    项目使用AdminLTE(基于Bootstrap 二次开发的框架)作为开发框架. 使用DataTables 的时候部分页面需要传参 给后台做筛选过滤. 但是不知道怎么将DataTables的参数 和自 ...

  5. Nacos笔记01——使用Nacos作为SpringCloud项目的服务注册中心

    前言 刚学SpringCloud时使用eureka作为服务注册中心,随着网飞公司eureka2.x不再更新,以及最近在公司实习接触到的SpringCloud项目是使用Nacos来做服务注册中心的,所以 ...

  6. glance

    第二篇glance— 镜像服务 一.glance介绍:              Glance是Openstack项目中负责镜像管理的模块,其功能包括虚拟机镜像的查找.注册和检索等. Glance提供 ...

  7. ubuntu16.04环境下在docker上部署javaweb项目简单案例

    因为一些原因,接触到了docker,经过一番研究,总算是有了一些自己的看法,有什么不对的地方,希望多多指教. 废话不多说,首先我这里使用的虚拟机安装的是ubuntu16.04版本,其他版本应该也可以. ...

  8. vue复制textarea文本域内容到粘贴板

    vue实现复制内容到粘贴板   方案:找到textarea对象(input同样适用),获取焦点,选中textarea的所有内容,并调用document.execCommand("copy&q ...

  9. Bootstrap源码

    1.Bootstrap Bootstrap是美国Twitter公司的设计师Mark Otto和Jacob Thornton合作基于HTML.CSS.JavaScript 开发的简洁.直观.强悍的前端开 ...

  10. unity图片保留周边,中间延伸

    1.先把图片切割,类似下面这样的 2.然后在使用的时候(选择图片类型的时候选择sliced)