php - 在 MySQL DB 上按目标文件夹存储多个上传内容

标签 php mysql arrays forms

我看到了一堆与我的类似但不完全相同的问题,在某种程度上我必须改变我当前在数据库上存储文件的方式。

我在第一个文件(getPic.php)上有这个表单:

<form enctype="multipart/form-data" method="POST" action="sendPics.php">
        <font size=4 color=DarkBlue><b>Choose 5 photos of your pet:</b></font><br><br>
    <input type="file" name="file[]" multiple="multiple" /><br><br>
    <input name="send" type="submit" value="Upload photos">

另一个是这个(sendPics.php)

$directory = "Images/";

if(!is_dir($directory)){ 
    echo "Folder does not exist";
}else{
    $file = isset($_FILES['file']) ? $_FILES['file'] : FALSE;
    for ($control = 0; $control < count($file['name']); $control++){

        $destiny = $directory."/".$file['name'][$control];
        if(move_uploaded_file($file['tmp_name'][$control], $destiny)){
            echo "Upload successful<br>"; 
        }else{
            echo "Error uploading the file";
        }   
    }
}

$destiny = "/".$destiny; 

我在 MySQL 中的表如下所示:

Field           | Type       
----------------+------------
 idPetsPics     | int(11)    
 linkProfilePic | varchar(60)
 linkPhoto1     | varchar(60)
 linkPhoto2     | varchar(60)
 linkPhoto3     | varchar(60)
 linkPhoto4     | varchar(60)
 Pet_idPet      | int(11)      //(FK with PetsID on Pet's table)

所以我需要存储上传图片的路径。目前我只能将第一张照片存储在数据库上,尽管所有 5 张照片都成功到达目标文件夹。现在我有:

$petID = $_SESSION['petID']; // obtained from a third file (queries to insert date into Pet)
require_once('dbConnection.php');


$insertPetPic = "INSERT INTO petPic (idPetsPics, linkProfilePic, Pet_idPet) VALUES (NULL, '$destiny', $petID[0])";
mysqli_query($conn, $insertFotoPet);

如何更改代码以存储所有 5 个路径?

最佳答案

对于成功移动的每个图像,您需要将图像的路径存储在某处,例如在 $paths 数组中:

$directory = "Images/";
$paths = array();

if(!is_dir($directory)){ 
    echo "Folder does not exist";
}else{
    $file = isset($_FILES['file']) ? $_FILES['file'] : FALSE;
    for ($control = 0; $control < count($file['name']); $control++){

        $destiny = $directory."/".$file['name'][$control];
        if(move_uploaded_file($file['tmp_name'][$control], $destiny)){
            $paths[] = $destiny;
            echo "Upload successful<br>"; 
        }else{
            echo "Error uploading the file";
        }   
    }
}

然后在查询中使用数组中的路径:

$insertPetPic = "INSERT INTO petPic (idPetsPics, linkProfilePic, linkPhoto1, linkPhoto2, linkPhoto3, linkPhoto4, Pet_idPet) VALUES (NULL, '$paths[0]', '$paths[1]', '$paths[2]', '$paths[3]', '$paths[4]', $petID[0])";

关于php - 在 MySQL DB 上按目标文件夹存储多个上传内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53579956/

相关文章:

PHP7.3 SQLSRV - 查询和存储时日期时间的格式不同

php - 没有关联条目的MySQL选择条目(在另一个表中)

mysql - 根据其自己的表中的值更新列

mysql - 在 MySQL Workbench 中创建连接时遇到问题

java - 文本文件的最后一行未正确存储到二维数组中

PHP 从不同的 mp3 创建 mp3

php - 选择一个表的部分并计算另一个表的行数

php - 动态更改iframe的src内容

ios - NSPredicate( swift ): SUBQUERY not working

javascript - 如何动态访问递增的json值