文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

在 PHP 中上传多个图像

2024-02-27 21:14

关注

在我们的 PHP 应用程序中,尤其是基于用户的应用程序中,有时我们可能需要一次上传多个文件。 借助 PHP 函数和 HTML 功能,这非常容易实现。

为了使之成为可能,我们需要根据您构建代码库的方式在我们的 HTML 文件或部分中指定表单操作,然后使用内置函数来处理该操作。

在本文中,我们将学习如何在 PHP 中上传多个图像,这为我们提供了从表单输入中指定所需文件、处理所有用户选择的文件以及上传或移动到所需位置的上下文。

了解 PHP 中多个文件上传的表单操作和 $_FILES

当用户将任何输入放入 HTML 表单时,我们使用 POST 方法将任何输入(从文本到文件)发送到我们的 PHP 应用程序所在的服务器端。


<form method='post' action='' enctype='multipart/form-data'>

enctype='multipart/form-data' 部分指定表单数据的编码方式,当我们在表单中使用文件上传时是必需的。

对于文件上传,我们需要输入类型文件和指定名称(可以是您决定的任何名称),文件。


<input type="file" name="file" id="file">

对于多文件上传,我们仍然需要输入类型文件,但现在不同的指定名称 file[] 和添加的属性 multiple。 添加 [] 表示输入字段可以处理多个文件。


<input type="file" name="files[]" multiple/>

在服务器端,全局变量 $_FILES 是一个关联数组,其中包含通过 HTTP POST 方法上传的文件,使我们能够适当地处理文件。


<?php

$_FILES["files"]

使用 move_uploaded_file() 在 PHP 中上传多张图片

现在我们了解了基础知识,我们需要上传多个文件。 让我们创建 PHP 表单来上传多张图片。


<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Multiple Image Upload</title>
</head>

<body>
    <form method="post" enctype="multipart/form-data" name="formUploadFile">
        <label>Select image(s) to upload:</label>
        <input type="file" name="files[]" multiple="multiple" />
        <input type="submit" value="Upload File" name="imgSubmit" />
    </form>
    <?php
    if (isset($_POST["imgSubmit"])) {
        $errors = [];
        $uploadedFiles = [];
        $extension = array("jpeg", "jpg", "png");
        $UploadFolder = "images";

        $counter = 0;

        foreach ($_FILES["files"]["tmp_name"] as $key => $tmp_name) {
            $temp = $_FILES["files"]["tmp_name"][$key];
            $name = $_FILES["files"]["name"][$key];

            if (empty($temp)) {
                break;
            }

            $counter++;
            $UploadOk = true;

            $ext = pathinfo($name, PATHINFO_EXTENSION);
            if (in_array($ext, $extension) == false) {
                $UploadOk = false;
                array_push($errors, $name . " isn't an image.");
            }

            if ($UploadOk == true) {
                move_uploaded_file($temp, $UploadFolder . "/" . $name);
                array_push($uploadedFiles, $name);
            }
        }

        if ($counter > 0) {
            if (count($errors) > 0) {
                echo "<b>Errors:</b>";
                echo "<br/><ul>";
                foreach ($errors as $error) {
                    echo "<li>" . $error . "</li>";
                }
                echo "</ul><br/>";
            }

            if (count($uploadedFiles) > 0) {
                echo "<b>Uploaded Files:</b>";
                echo "<br/><ul>";
                foreach ($uploadedFiles as $fileName) {
                    echo "<li>" . $fileName . "</li>";
                }
                echo "</ul><br/>";

                echo count($uploadedFiles) . " iamge(s) are successfully uploaded.";
            }
        } else {
            echo "Please, Select image(s) to upload.";
        }
    }
    ?>
</body>

</html>

检查 $_POST[] 变量是否使用 isset() 函数设置,初始化重要变量,并设置文件上传所需的扩展名。


if (isset($_POST["imgSubmit"])) {
        $errors = [];
        $uploadedFiles = [];
        $extension = array("jpeg", "jpg", "png");
        $UploadFolder = "images";

之后,我们循环遍历已通过 $_FILES[] 变量处理过的多个图像,然后使用 pathinfo() 检查扩展名,如果为真,我们将图像移动到指定文件夹 $UploadFolder 使用 move_uploaded_file() 函数,并将图像的名称推送到 $uploadedFiles 变量。


foreach ($_FILES["files"]["tmp_name"] as $key => $tmp_name) {
    $temp = $_FILES["files"]["tmp_name"][$key];
    $name = $_FILES["files"]["name"][$key];

    if (empty($temp)) {
        break;
    }

    $counter++;
    $UploadOk = true;

    $ext = pathinfo($name, PATHINFO_EXTENSION);
    if (in_array($ext, $extension) == false) {
        $UploadOk = false;
        array_push($errors, $name . " isn't an image.");
    }

    if ($UploadOk == true) {
        move_uploaded_file($temp, $UploadFolder . "/" . $name);
        array_push($uploadedFiles, $name);
    }
}

最后,我们显示了存在的错误和上传的文件。


if ($counter > 0) {
    if (count($errors) > 0) {
        echo "<b>Errors:</b>";
        echo "<br/><ul>";
        foreach ($errors as $error) {
            echo "<li>" . $error . "</li>";
        }
        echo "</ul><br/>";
    }

    if (count($uploadedFiles) > 0) {
        echo "<b>Uploaded Files:</b>";
        echo "<br/><ul>";
        foreach ($uploadedFiles as $fileName) {
            echo "<li>" . $fileName . "</li>";
        }
        echo "</ul><br/>";

        echo count($uploadedFiles) . " image(s) are successfully uploaded.";
    }
} else {
    echo "Please, Select image(s) to upload.";
}

向浏览器提供的 PHP 文件。

将 PHP 文件提供给浏览器

选择图像并上传图像。

选择要上传的图像

然后,显示上传的文件。

显示上传的文件

上传的图片:

上传的图片

如果您选择的文件不是图像,则会出现错误。

error

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯