将多个文件上传到mySQL然后添加到Session

时间:2014-05-25 05:04:17

标签: php mysql arrays session

好的,为了解释我想要实现的目标,我希望用户能够在没有多个文件输入字段的情况下进行多文件上传(特别是图像),所以我使用了<input type="file" multiple="multiple" name="files[]">我的页面。

以下是我的PHP:

session_start();
include('connect.php');

// Connect to server and select databse.
mysql_connect("$host", "$username", "$password")or die("cannot connect"); 
mysql_select_db("$db_name")or die("cannot select DB");
$tbl_name="Pictures"; // Table name 

if(isset($_POST['submit'])) {
    if(isset($_FILES['files'])){
    $errors= array();   
    $files = array();

    for($i=0; $i<count($_FILES['files']['name']); $i++) {
        $tmpFilePath = $_FILES['files']['tmp_name'][$i];
        $file_name = $i.$_FILES['files']['name'][$i];
        $file_size =$_FILES['files']['size'][$i];
        $file_tmp =$_FILES['files']['tmp_name'][$i];
        $file_type=$_FILES['files']['type'][$i];    

        $desired_dir="images";
        $random_digit=rand(0000,9999);

        if ($tmpFilePath != ""){
            $newFilePath = "images/" . $random_digit . $_FILES['files']['name'][$i];
        }

        if($file_size > 2097152){
            $errors[]='File size must be less than 2 MB';
        } else {
            move_uploaded_file($tmpFilePath, $newFilePath);
        }

        $files = array($newFilePath);
        $_SESSION['files'] = $files;
    }
    }
}

所以目前正在做的是将文件添加到我的目录,这是正常工作,我已经做到这样,文件之前有一个随机数,以避免重复,因为会有很多文件上传。它正在上传多个文件,但我接下来要做的是转到下一页,根据已上传的文件数打印出一些文本输入字段,允许用户为每个文件添加字幕。然后,一旦提交,每个文件及其标题将被插入到mySQL数据库中。

我想到的最简单的方法是将每个$ newFilePath(这是每个图像的文件路径)上传到一个数组中。我尝试了这个并使用以下方法打印数组:

foreach($files as $f) {
echo $f . '<br>';
}

仅提供了上传的第一个文件,而不是所有文件。我喜欢然后将数组添加到$ _SESSION中,以便我可以在另一个页面上使用它们,但是一旦我对它进行排序,它可能会在一个页面上完成所有操作。有什么想法吗?

1 个答案:

答案 0 :(得分:0)

$files = array($newFilePath);

应该是

$files[] = $newFilePath;

您将能够直接将数组直接添加到会话数据中:

$_SESSION['files'] = $files;