在 PHP 中上传多个图像

admin 阅读:91 2024-02-29

php小编鱼仔为您介绍如何在php中上传多个图像。在网站开发中,经常需要实现批量上传图片的功能,为了提高用户体验和效率,上传多个图像是一个常见需求。php提供了丰富的函数和技术来实现这一功能,包括使用表单、处理上传文件、循环处理多个文件等。通过本文的指导,您将学会如何在php中轻松上传多个图像,为您的网站添加更多互动和创意元素。

为了使之成为可能,我们需要根据您构建代码库的方式在我们的 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 中上传多个图像

选择图像并上传图像。

在 PHP 中上传多个图像

然后,显示上传的文件。

显示上传的文件

上传的图片:

上传的图片

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

error

声明

1、部分文章来源于网络,仅作为参考。
2、如果网站中图片和文字侵犯了您的版权,请联系1943759704@qq.com处理!