PHP多图上传预览实现教程
时间:2026-01-06 14:52:49 327浏览 收藏
在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是文章学习者,那么本文《PHP多图上传预览实现方法》就很适合你!本篇内容主要包括##content_title##,希望对大家的知识积累有所帮助,助力实战开发!
首先实现前端多图选择与实时预览,通过input[file]和FileReader读取文件并展示缩略图;接着使用FormData异步上传至PHP后端,将文件存入temp_uploads目录并返回文件名;然后通过get_temp_images.php扫描目录,页面加载时重新渲染已上传的临时图片,实现刷新回显;最后建议增加文件校验、过期清理和用户隔离机制以提升安全性与稳定性。

实现多图上传并预览,需要前端 JavaScript 实时展示用户选择的图片,后端 PHP 接收文件并临时存储,同时支持页面刷新后回显已上传的临时图片。以下是完整的实现方案。
前端 JS 实现多图选择与实时预览
使用 HTML 的 input[type=file] 支持多选,并通过 JavaScript 读取文件生成预览图。
HTML 部分:
<input type="file" id="imageUpload" multiple accept="image/*">
JavaScript 部分(原生 JS):
const input = document.getElementById('imageUpload');
const preview = document.getElementById('previewContainer');
input.addEventListener('change', function() {
preview.innerHTML = ''; // 清空之前的预览
const files = this.files;
Array.from(files).forEach(file => {
if (!file.type.match('image.*')) return;
const reader = new FileReader();
reader.onload = function(e) {
const img = document.createElement('img');
img.src = e.target.result;
img.style.width = '100px';
img.style.height = '100px';
img.style.margin = '5px';
preview.appendChild(img);
};
reader.readAsDataURL(file);
});
});
PHP 后端接收并临时存储上传图片
前端通过 FormData 提交文件,PHP 将其保存到临时目录(如 temp_uploads/),并返回文件名用于后续处理。
改进的 JS:添加上传功能
// 添加上传按钮
// <button onclick="uploadImages()">上传图片</button>
function uploadImages() {
const files = input.files;
const formData = new FormData();
Array.from(files).forEach(file => {
formData.append('images[]', file);
});
fetch('upload.php', {
method: 'POST',
body: formData
})
.then(response => response.json())
.then(data => {
console.log('上传成功:', data);
loadTempImages(); // 上传后刷新回显
})
.catch(error => {
console.error('上传失败:', error);
});
}
PHP 处理脚本(upload.php):
<?php
$uploadDir = 'temp_uploads/';
if (!is_dir($uploadDir)) {
mkdir($uploadDir, 0777, true);
}
$response = ['success' => [], 'error' => []];
$files = $_FILES['images'] ?? null;
if ($files && !empty($files['name'][0])) {
$count = count($files['name']);
for ($i = 0; $i < $count; $i++) {
$tmpName = $files['tmp_name'][$i];
$originalName = $files['name'][$i];
$fileName = uniqid('img_') . '_' . time() . '.' . pathinfo($originalName, PATHINFO_EXTENSION);
$filePath = $uploadDir . $fileName;
if (in_array(mime_content_type($tmpName), ['image/jpeg', 'image/png', 'image/gif'])) {
if (move_uploaded_file($tmpName, $filePath)) {
$response['success'][] = $fileName;
} else {
$response['error'][] = $originalName;
}
} else {
$response['error'][] = $originalName . ' 不是有效图片';
}
}
}
echo json_encode($response);
页面加载时回显已上传的临时图片
用户刷新页面后,从服务器获取已上传的临时图片列表并重新生成预览。
JS 加载已上传图片:
function loadTempImages() {
fetch('get_temp_images.php')
.then(response => response.json())
.then(images => {
const preview = document.getElementById('previewContainer');
images.forEach(fileName => {
const img = document.createElement('img');
img.src = 'temp_uploads/' + fileName;
img.dataset.filename = fileName;
img.style.width = '100px';
img.style.height = '100px';
img.style.margin = '5px';
preview.appendChild(img);
});
});
}
// 页面加载时执行
window.onload = function() {
loadTempImages();
};
get_temp_images.php 获取临时目录中的图片文件名:
<?php
$dir = 'temp_uploads/';
$images = [];
if (is_dir($dir)) {
foreach (scandir($dir) as $file) {
if (in_array(pathinfo($file, PATHINFO_EXTENSION), ['jpg', 'jpeg', 'png', 'gif'])) {
$images[] = $file;
}
}
}
echo json_encode($images);
注意事项与优化建议
- 临时文件应设置过期机制,例如每天清理超过 24 小时的文件
- 可增加删除临时图片的接口,避免冗余存储
- 生产环境需校验文件大小、限制数量、防止恶意上传
- 考虑使用 session 或数据库标记用户专属临时文件,避免冲突
基本上就这些。通过前端预览 + 后端临时存储 + 回显机制,可以实现流畅的多图上传体验。不复杂但容易忽略细节,比如 MIME 校验和路径安全。
到这里,我们也就讲完了《PHP多图上传预览实现教程》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于php,多图上传的知识点!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
438 收藏
-
276 收藏
-
264 收藏
-
430 收藏
-
254 收藏
-
364 收藏
-
304 收藏
-
397 收藏
-
341 收藏
-
128 收藏
-
167 收藏
-
366 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习