2

我是 php 新手,我正在尝试制作一个多图像上传器。我的表格如下所示:

<form action="" method="post" enctype="multipart/form-data">
    <p class="style2">Izberi datoteko: <br /><input type="file" name="image" multiple="multiple" /></p>
    <p class="style2">
        Izberi Album: <br />
            <select name="album_id">
                <?php 
                    foreach ($albums as $album) {
                        echo '<option value="', $album['id'] ,'">', $album['name'] ,'</option>';
                    }
                ?>
            </select>
    </p>
    <p class="style2"><input type="submit" value="Naloži Slike" /></p>
</form>

在 php 方面,我做了类似的事情:

if (isset($_FILES['image'], $_POST['album_id'])) {
$image_name = $_FILES['image']['name'];
$image_size = $_FILES['image']['size'];
$image_temp = $_FILES['image']['tmp_name'];

$allowed_ext = array('jpg', 'jpeg', 'png', 'gif');
$a = explode('.', $image_name);
$image_ext = strtolower(end($a));

$album_id = $_POST['album_id'];

$errors = array();

if (empty($image_name) || empty($album_id)) {
    $errors[] = '<p class="style2">Nekaj manjka!</p>';
} else {

    if (in_array($image_ext, $allowed_ext) === false) {
        $errors[] = '<p class="style2">Izbrani tip datoteke ni dovoljen!</p>';
    }

    if ($image_size > 2097152) {
        $errors[] = '<p class="style2">Izbrana datoteka je prevelika! Maksimalna velikost datoteke mora biti 2mb!</p>';
    }           
}

if (!empty($errors)) {
    foreach ($errors as $error) {
        echo $error;
    }
} else {
    upload_image($image_temp, $image_ext, $album_id);
    header('Location: view_album.php?album_id='.$album_id);
    exit();
} 

}

我创建了一个将图像放入数据库的函数。这个函数看起来像这样:

function upload_image($image_temp, $image_ext, $album_id) {
$album_id = (int)$album_id;

mysql_query("INSERT INTO `images` VALUES ('', '". $_SESSION['user_id'] ."', '$album_id', UNIX_TIMESTAMP(), '$image_ext')"); 

$image_id = mysql_insert_id();
$image_file = $image_id.'.'.$image_ext;
move_uploaded_file($image_temp, 'galerija/'.$album_id.'/'.$image_file);

create_thumb('galerija/'.$album_id.'/', $image_file, 'galerija/thumbs/'.$album_id.'/');
}

这适用于仅上传一张图片。我试图为多个选择文件创建一个表单,我可以选择更多图像,但在数据库中只获取第一个图像。我试图放入foreach()我的脚本,但我不知道我必须在哪里以及如何放入它。那么我该如何更改我的脚本以便我可以将更多图像上传到我的数据库中?我就是想不通。任何帮助都会很棒!

4

4 回答 4

3

A. PHP 不会像那样看到你的多个文件

代替

  <input type="file" name="image" multiple="multiple" />

 <input type="file" name="image[]" multiple="multiple" />

要遍历此文件,您需要类似

foreach ( $_FILES['image']['tmp_name'] as $key => $val ) {

    $fileName = $_FILES['image']['name'][$key];
    $fileSize = $_FILES['image']['size'][$key];
    $fileTemp = $_FILES['image']['tmp_name'][$key];

    $fileExt = pathinfo($fileName, PATHINFO_EXTENSION);
    $fileExt = strtolower($fileExt);

    // Continue
}
于 2012-10-14T21:58:18.370 回答
2

你会发现这很有帮助:

<?php
$target = "images/".$_FILES['image_upload']['name'];
$image_upload = mysql_real_escape_string(($_FILES['image_upload']['name']));
move_uploaded_file($_FILES['image_upload']['tmp_name'], $target);
for($i=2;$i<5;$i++)
{
if(!empty($_FILES['image_upload'.$i])):
$target = "images/".$_FILES['image_upload'.$i]['name'];
$image_upload.= ",".mysql_real_escape_string(($_FILES['image_upload'.$i]['name']));
 move_uploaded_file($_FILES['image_upload'.$i]['tmp_name'], $target);
 endif;
 }
 mysql_query("INSERT INTO `images` VALUES ('', '". $_SESSION['user_id'] ."', '$album_id', UNIX_TIMESTAMP(), '$image_upload')");
 ?>

使用 ftp 在您的根目录中创建一个文件夹。将其命名为“图像”。所有图像都将上传到此文件夹。根据您的更改输入类型的名称。

编码快乐!!

于 2012-10-17T06:50:11.277 回答
0

将你的名字="image" 更改为 name="image[]"

例子:

<pre><?php print_r($_FILES); ?></pre>
<form action="" method="post" enctype="multipart/form-data">
<input type="file" name="image[]" multiple="multiple" />
<input type="submit">
</form>
于 2012-10-14T21:58:20.437 回答
0

您收到了一张图片到数据库,因为您只发送了一张图片(不是在 foreach 循环中),但失败了:

upload_image($image_temp, $image_ext, $album_id);

您应该以 HTML 形式添加上传图像的数组,例如:

<input type="file" name"image[]" multiple="multiple" />
<input type="file" name"image[]" multiple="multiple" />

并接收一个图像循环:

if (isset($_POST["image"]))
{
    $album_id = (int)$_POST['album_id'];

    foreach ($_FILES["image"] as $images)
    {

        $image_temp = $images['tmp_name'];
        $image_name = $images['name'];

        $allowed_ext = array('jpg', 'jpeg', 'png', 'gif');
        $a = explode('.', $image_name);
        $image_ext = strtolower(end($a));


        upload_image($image_temp, $image_ext, $album_id);
    }
}

如果您不转储它以var_dump($_FILES)检查 HTML 表单中的数组。

请注意,您也是 SQL 注入的受害者!在 Stackoverflow 中阅读有关 SQL 注入的信息。

于 2012-10-14T21:58:49.880 回答