$ _FILES数组但只有第一个文件上传

时间:2013-01-18 15:05:23

标签: php javascript file-upload image-uploading

我正在尝试上传多个图片文件。如果图像名称是“icon.jpg”,那么它将被移动到与其他图像不同的位置 - 这似乎工作正常,但只有第一张图像被上传和移动。

脚本在第一张图片后停止并显示“查询为空”,即使我正在尝试上传至少4或5张其他图片。

$id = '01';
foreach($_FILES['file']['name'] as $n => $image) 
if(!empty($image)) {
{
 if ($image == 'icon.jpg'){
  $target_path = "../images/articles/".$id."_small.jpg";
  } else {
  $target_path = "../images/galleries/".$id."/pk_hb" . $id.".jpg";
  }
  move_uploaded_file($_FILES['file']['tmp_name'][$n], $target_path);
$id++;
 }
}

我已经包含了我正在使用的动态JS上传表单,以防这是问题所在:

<form action="<? echo $_SERVER['PHP_SELF'];?>" enctype="multipart/form-data" method="post" name="add">
Image 1: <input name='file[]' type='file' accept="image/*" />
<div id='file_tools'>
    <img src='../images/top/file_add.png' id='add_file' title='Add new input'/>
    <img src='../images/top/file_del.png' id='del_file' title='Delete'/>
</div>

<script type='text/javascript'>
$(document).ready(function(){
var counter = 2;
$('#del_file').hide();
$('img#add_file').click(function(){
    $('#file_tools').before('Image '+counter+': <input name="file[]" type="file" accept="image/*" />');
    $('#del_file').fadeIn(0);
counter++;
});
$('img#del_file').click(function(){
    if(counter==3){
        $('#del_file').hide();
    }   
    counter--;
    $('#f'+counter).remove();
});
});
</script>
    <input class="submit" type="submit" name="add" value="Submit" />
</form>

添加了var_dump($ _ FILES)

的内容
array(1) { 
["file"]=> array(5) 
{ 
 ["name"]=> array(1) { [0]=> string(11) "cooley1.jpg" } 
 ["type"]=> array(1) { [0]=> string(10) "image/jpeg" } 
 ["tmp_name"]=> array(1) { [0]=> string(18) "/var/tmp/phpLYaj7U" } 
 ["error"]=> array(1) { [0]=> int(0) } 
 ["size"]=> array(1) { [0]=> int(106241) } 
} 
} 

1 个答案:

答案 0 :(得分:1)

<强>更新

$_POST不同,您不能通过将所有$_FILES的{​​{1}}设置为name来将文件数组发送到inputfile[]自动包含您在数组中上传的所有文件:)其中密钥是文件$_FILES元素的name

您必须将每个文件input的名称更改为inputfile_1,... file_2,以使脚本了解您有多个文件上传。

您还必须检查file_n max-file-uploads的有效值http://php.net/manual/en/ini.core.php#ini.max-file-uploads