1

我还有另一个问题要解决:Putting PHP array into MySQL with additional columns

我正在尝试根据扩展名将文件放入单独的文件夹中。但是,无论我打印出来时数组显示什么,这些文件最终都会以相同的文件名保存在同一个文件夹中。

这是我目前拥有的数组:

$files[$key] = array
(
    $file_name = basename($guid." - ".$_FILES['file']['name'][$key]),
    $file_type = $_FILES['file']['type'][$key],
    $file_size = $_FILES['file']['size'][$key],
    $file_tmp = $_FILES['file']['tmp_name'][$key],
    $extension = strtolower(substr($file_name, strlen($file_name)-4, strlen($file_name))),
    $tgt = $_FILES['file']['name'][$key]
);

这是我目前拥有的数组输出:

Array
(
[0] => Array
    (
        [0] => 966c5853-63b4-4570-a3ee-bd5629688038 - cycles.pdf
        [1] => application/pdf
        [2] => 331881
        [3] => C:\xampp\tmp\php9738.tmp
        [4] => .pdf
        [5] => cycles.pdf
    )

[1] => Array
    (
        [0] => 966c5853-63b4-4570-a3ee-bd5629688038 - landofstoopid.bmp
        [1] => image/bmp
        [2] => 310342
        [3] => C:\xampp\tmp\php9758.tmp
        [4] => .bmp
        [5] => landofstoopid.bmp
    )

)

这是我拥有的 SQL 查询生成:

$new = array();
foreach($files as $key => $value)
{
    $new[] = "'".implode("','", $value)."', '$guid', '$getthedate', '$gettime', '$mailid', '$target'";
}
$query = "(".implode("), (",$new).")";

这是 SQL 查询的输出

INSERT INTO files (filename, filetype, filesize, filetempname, guid, dateadded, timeadded, mailid, target) 
VALUES ('966c5853-63b4-4570-a3ee-bd5629688038 - cycles.pdf','application/pdf','331881','C:\xampp\tmp\php9738.tmp','.pdf','cycles.pdf', '966c5853-63b4-4570-a3ee-bd5629688038', '13 Jun 2013', '10:25:07', '77', 'files/pics/landofstoopid.bmp'), 
('966c5853-63b4-4570-a3ee-bd5629688038 - landofstoopid.bmp','image/bmp','310342','C:\xampp\tmp\php9758.tmp','.bmp','landofstoopid.bmp', '966c5853-63b4-4570-a3ee-bd5629688038', '13 Jun 2013', '10:25:07', '77', 'files/pics/landofstoopid.bmp')

这就是我必须确定文件应该放在哪里

$pics = array(".bmp", ".gif", ".jpg", "jpeg", ".png"); //5              
$docs = array(".doc", "docx", ".odt", ".pdf", ".ppt", "pptx", ".rtf", ".txt", ".xls", "xlsx"); //10             
$misc = array(".csv", ".htm", "html", ".php", ".pkt", ".rar", ".sql", ".xpi", ".zip"); //9

if (in_array($extension,$pics))
{
    $target = "".FILES."/".FUP_PICS."/";
}
else if (in_array($extension,$docs))
{
    $target = "".FILES."/".FUP_DOCS."/";
}
else if (in_array($extension,$misc))
{
    $target = "".FILES."/".FUP_MISC."/";
}
$target = $target.$tgt;

我在 foreach 循环内部和外部都尝试过此方法以获取多个文件的值,并且以相同的方式结束。

文件的目标始终取决于最后一个文件名和扩展名。如上所述,我有一个 .pdf 和一个 .bmp,pdf 应该放在 docs 文件夹中,bmp 应该放在 pics 文件夹中。但是,这两个文件都被发送到 pics 文件夹,并且名称更改为数组中的最后一个文件。

只是想知道我是否可以得到一些关于我哪里出错的指示,或者这是否可能。

我要补充一点,当文件作为单个文件上传时,不会发生此问题,并且文件会转到正确的文件夹。

提前致谢

4

1 回答 1

1

您的代码选择在哪个文件夹中放置文件,尽管您可能应该对无法识别的扩展有一个默认操作。

由于这里的一切似乎都井然有序,因此问题很可能出在其他地方。

您的 sql 结构使我怀疑您没有在 sql 生成代码迭代之间更改目标。你确定你的变量名拼写正确吗?它总是被使用的最后一个文件的扩展名和名称吗?对我来说,这看起来像是一个保留变量问题。

考虑删除代码以确定您放置文件的位置并用函数 vis 替换它:

function set_target($extension)
    {
    $target="";
    $pics = array(".bmp", ".gif", ".jpg", "jpeg", ".png"); //5              
    $docs = array(".doc", "docx", ".odt", ".pdf", ".ppt", "pptx", ".rtf", ".txt", ".xls", "xlsx"); //10             
    $misc = array(".csv", ".htm", "html", ".php", ".pkt", ".rar", ".sql", ".xpi", ".zip"); //9

    if (in_array($extension,$pics))
        {
        $target = "".FILES."/".FUP_PICS."/";
        }
        else if (in_array($extension,$docs))
        {
        $target = "".FILES."/".FUP_DOCS."/";
        }
        else if (in_array($extension,$misc))
        {
        $target = "".FILES."/".FUP_MISC."/";
        }
    $target = $target.$tgt;
    echo $target."<BR>"; //this line for debugging - should see as many lines as you have files.  If not, the problem is in your iteration loop.
    return($target);
    }

而不是内联代码。这可能有助于揭示未正确分配目标的位置,并且无论如何都是良好的做法。

或者,不要尝试进行单个 SQL 查询,而只是为每个文件生成一个新 SQL。

如果您提供其余的代码,您也许能够得到更完整的答案,但我的猜测是这将解决它。生成你的 sql 的位会很有用。

于 2013-06-13T11:15:42.580 回答