使用pdo在php中上载多个图像

使用pdo在php中上载多个图像,php,mysql,Php,Mysql,我打算一次上传许多图片到一个文件夹中,并将它们的信息保存到数据库中 目前,无论我选择一个还是多个,代码都会正确地将这些图像上传到文件夹中。但是,当我选择多个时,它不会将图像信息存储到数据库中,而只是将图像上载到文件夹中。如果我选择一个图像,那么它会将该图像的信息正确地存储到数据库中 下面是我的代码 <?php #connect to the db require_once('db.inc.php'); ?> <html> <head> </head>

我打算一次上传许多图片到一个文件夹中,并将它们的信息保存到数据库中

目前,无论我选择一个还是多个,代码都会正确地将这些图像上传到文件夹中。但是,当我选择多个时,它不会将图像信息存储到数据库中,而只是将图像上载到文件夹中。如果我选择一个图像,那么它会将该图像的信息正确地存储到数据库中

下面是我的代码

<?php
#connect to the db
require_once('db.inc.php');
?>
<html>
<head>
</head>
<body>
<form action="" method="POST" enctype="multipart/form-data">
    <input type="file" name="files[]" multiple/>
    <input type="submit"/>
</form>
<?php
if(isset($_FILES['files'])){
    $errors= array();
    foreach($_FILES['files']['tmp_name'] as $key => $tmp_name ){
        $file_name = $key.$_FILES['files']['name'][$key];
        $file_size =$_FILES['files']['size'][$key];
        $file_tmp =$_FILES['files']['tmp_name'][$key];
        $file_type=$_FILES['files']['type'][$key];  
        if($file_size > 2097152){
            $errors[]='File size must be less than 2 MB';
        }try{       
$query ="INSERT into tish_images(FILE_NAME,FILE_SIZE,FILE_TYPE)
VALUES(:FILE_NAME,:FILE_SIZE,:FILE_TYPE)";
$insert = $con->prepare($query);
$insert->execute(array(
':FILE_NAME'=>$file_name,
':FILE_SIZE'=>$file_size,
':FILE_TYPE'=>$file_type));
}catch(PDOException $e){
echo $e->getMessage();
}
$desired_dir="image_uploads";
        if(empty($errors)==true){
            if(is_dir($desired_dir)==false){
                mkdir("$desired_dir", 0700);// Create directory if it does not exist
            }
            if(is_dir("$desired_dir/".$file_name)==false){
                move_uploaded_file($file_tmp,"image_uploads/".$file_name);
            }else{                                  //rename the file if another one exist
                $new_dir="image_uploads/".$file_name.time();
                 rename($file_tmp,$new_dir) ;               
            }


        }else{
                print_r($errors);
        }
    }
    if(empty($error)){
        echo "Success";
    }
}
?>

</body>
</html>


我看不出有太多的错误,但我已经围绕pdo对代码进行了一些重构,使其更具可读性,并且您现在只准备了一次。我也在try块中移动了实际的移动文件,因此只有在数据库执行中没有错误时才尝试(您应该检查插入的状态-查看$stmt->errorCode()或$stmt->errorInfo())。



我看不出有太多的错误,但我已经围绕pdo对代码进行了一些重构,使其更具可读性,并且您现在只准备了一次。我也在try块中移动了实际的移动文件,因此只有在数据库执行中没有错误时才尝试(您应该检查插入的状态-查看$stmt->errorCode()或$stmt->errorInfo())。

是的,您修复了它。我感谢您的帮助,现在我要做的是将这些图像分配给上传它们的人。例如,你登录并上传这些图片。那么当你再次登录时,你将能够单独查看而不是其他用户?前进的方向是什么idea@humphrey-最好的做法是尝试编写代码,将图像分配给用户自己。如果你陷入困境,那么用你迄今为止所尝试过的内容发布另一个问题。@humphrey-如果Ian的帖子解决了你最初的问题,那么你应该通过选择他的回答中的“勾号”来接受它作为正确答案:)欢迎来到StackOverflow@DMK你是说他们说这篇文章对你有用吗?@humphrey-是的,你把它修好了,我很感激在你们的帮助下,我现在想要的是把这些图片分配给上传它们的人。例如,你登录并上传这些图片。那么当你再次登录时,你将能够单独查看而不是其他用户?前进的方向是什么idea@humphrey-最好的做法是尝试编写代码,将图像分配给用户自己。如果你陷入困境,那么用你迄今为止所尝试过的内容发布另一个问题。@humphrey-如果Ian的帖子解决了你最初的问题,那么你应该通过选择他的回答中的“勾号”来接受它作为正确答案:)欢迎来到StackOverflow@DMK你是说他们说这篇文章对你有用吗?@humphrey-
<?php
if(isset($_FILES['files'])){
    $query = "INSERT into tish_images(`FILE_NAME`,`FILE_SIZE`,`FILE_TYPE`)
             VALUES(:FILE_NAME,:FILE_SIZE,:FILE_TYPE)";
    $stmt  = $con->prepare($query);
    $errors= array();
    foreach($_FILES['files']['tmp_name'] as $key => $error ){
        if ($error != UPLOAD_ERR_OK) {
            $errors[] = $_FILES['files']['name'][$key] . ' was not uploaded.';
            continue;
        }
        $file_name = $key.$_FILES['files']['name'][$key];
        $file_size = $_FILES['files']['size'][$key];
        $file_tmp  = $_FILES['files']['tmp_name'][$key];
        $file_type = $_FILES['files']['type'][$key];  
        if($file_size > 2097152){
            $errors[] = 'File size must be less than 2 MB';
            continue;
        }
        try{       
            $stmt->bindParam( ':FILE_NAME', $file_name , PDO::PARAM_STR );
            $stmt->bindParam( ':FILE_SIZE', $file_size, PDO::PARAM_STR );
            $stmt->bindParam( ':FILE_TYPE', $file_type, PDO::PARAM_STR );
            $stmt->execute();

            $desired_dir="image_uploads";

            if(is_dir($desired_dir)==false){
                mkdir($desired_dir, 0700);// Create directory if it does not exist
            }
            if(is_file($desired_dir.'/'.$file_name)==false){
                move_uploaded_file($file_tmp,$desired_dir.'/'.$file_name);
            }else{    //rename the file if another one exist
                $new_file=$desired_dir.'/'.$file_name.time();
                move_uploaded_file($file_tmp,$new_file) ;               
            }
        }catch(PDOException $e){
            $errors[] = $file_name . 'not saved in db.';
            echo $e->getMessage();
        }   
    }
    if(empty($error)){
        echo "Success";
    }
}
?>