1

我正在尝试使用 jQuery 创建一个文件上传器,它上传一个文件,用时间戳重命名它并将其注册到数据库中。基本上,它将带​​有表单的文件发送到服务器,第二个脚本将其重命名并将文件移动到正确的目录。这没有任何问题。问题是,我还想发送应该创建此数据库条目的表名。

所以 index.php 包含以下形式:

<div id="uploaderMain">
        <p>Upload Your Files</p>
        <form method="post" enctype="multipart/form-data"  action="./upload.php">
            <input type="file" name="images" id="images" />
            <input type="hidden" name="List" id="List" value="<?php echo $DBTable; ?>" />
            <button type="submit" id="btn">Upload Files!</button>
        </form>

    <div id="response"></div>
        <ul id="image-list">
        </ul>
    </div>

jQuery 代码如下所示:

$.ajax({
    url: "./uploader/upload.php",
    type: "POST",
    data: formdata,
    processData: false,
    contentType: false,
    success: function (res) {
        document.getElementById("response").innerHTML = res;
        }
      });

upload.php 看起来像这样:

   <?php
//include db configuration file

include_once('../../db.php');

$List = $_POST['List'];

// get the time stamp for the uploaded file
date_default_timezone_set('EST');
$date = new DateTime();
$date = $date->getTimestamp();
// echo $date;


foreach ($_FILES["images"]["error"] as $key => $error) {
    if ($error == UPLOAD_ERR_OK) {
        $name = $_FILES["images"]["name"][$key];
        // store the file name and the file ending in 2 variables
        $fileEnding = substr($name, -4,4);
        $fileName = substr($name, 0, (strlen($name)-4));
        $uploadName =  $fileName."_".$date.$fileEnding;
        move_uploaded_file( $_FILES["images"]["tmp_name"][$key], "./uploads/" . $uploadName);
    }
}

之后我想写入数据库。问题是,$_POST['LIST'] 语句没有提供我的 DBTable 名称。

谁能给我一个提示?

干杯丹

4

2 回答 2

0

如果List控件有任何值,您可以从浏览器中检查源代码吗?

于 2013-02-17T16:20:09.507 回答
0

我认为您需要将其添加到您的 jQuery 代码中:

formdata.append('List', '[your value]');

请注意:在 PHP 中,所有文件都将进入 $_FILES。其他所有内容都将进入 $_POST。

如果这不起作用,请确保您还有以下代码:

var formdata = new FormData();          
jQuery.each($('input[type="file"]')[0].files, function(i, file) {
    formdata.append(i, file);
});
于 2013-02-18T21:02:55.403 回答