PHP多文件上传需先确保PHP配置允许且表单含enctype="multipart/form-data",再按$_FILES二维结构遍历每个文件,逐一校验error、类型、重命名并安全存储。
PHP 文件上传的核心在于正确配置服务器环境、合理处理表单提交、安全校验文件并完成存储。多文件上传不是简单循环,关键在 $_FILES 数组结构的理解与遍历方式。
上传功能依赖两个基本条件:PHP 配置允许、HTML 表单正确声明。
file_uploads = On(php.ini),并留意 upload_max_filesize 和 post_max_size 是否足够(如设为 20M)enctype="multipart/form-data",否则 $_FILES 为空; 的 name 属性需带中括号(如 name="files[]")才能支持多选或多字段浏览器选择多个文件后,$_FILES['files'] 不是扁平数组,而是按字段名维度组织的二维结构:
上传 3 个文件,$_FILES['files'] 实际长这样:
Array( 'name' => ['a.jpg', 'b.pdf', 'c.png'], 'type' => ['image/jpeg', 'application/pdf', 'image/png'], 'tmp_name' => ['/tmp/phpabc123', '/tmp/phpdef456', '/tmp/phpghi789'], 'error' => [0, 0, 0], 'size' => [10240, 81920, 5120] )
这意味着不能直接 foreach($_FILES['files'] as $file)——那遍历的是 name、type 等子键。正确做法是先用 count($_FILES['files']['name']) 获取数量,再按索引逐个取值。
每一份上传都应独立完成以下校验与操作,不可跳过:
0(UPLOAD_ERR_OK),其他值如 1(超 php.ini 限制)、4(未选文件)需明确提示$_FILES['type'](易伪造),改用 finfo_file() 或扩展名白名单(如 in_array(pathinfo($nam
e, PATHINFO_EXTENSION), ['jpg','png','pdf']))uniqid() . '_' . mt_rand(100,999) . '.' . $ext 生成唯一名move_uploaded_file($tmp_name, $target_path),目标路径不能由用户输入拼接,且目录需有写权限但不在 Web 可访问根目录下(或通过脚本控制访问)HTML 部分(upload.html):
PHP 处理部分(upload.php):
上传结果";
if (!empty($uploaded)) {
echo "成功:
" . implode('
', $uploaded) . "
";
}
if (!empty($errors)) {
echo "错误:
" . implode('
', $errors) . "
";
}
} else {
echo "请通过表单上传文件";
}
?>
基本上就这些。核心是把多文件看作“一批独立任务”,每个都走完校验 → 过滤 → 存储流程。不复杂但容易忽略 error 判断和类型二次验证。