将多个图像上传到mysql数据库

时间:2017-11-16 14:04:21

标签: php mysql database

我对PHP比较新。我需要点击一下按钮就可以将多个图像上传到数据库。这是代码。我知道我必须添加一个foreach循环来单独浏览每个图像(单独插入图像)但我似乎找不到为每个循环插入的正确位置。任何答案都将非常感谢。

<?php

    error_reporting( ~E_NOTICE ); // avoid notice

    require_once 'dbconfig.php';

    if(isset($_POST['btnsave']))
    {
        $carname = $_POST['car_name'];// car name
        $carmodel = $_POST['car_model'];// car model
        $caramount = $_POST['car_amount'];// car amount

        $imgFile = $_FILES['car_image']['name'];
        $tmp_dir = $_FILES['car_image']['tmp_name'];
        $imgSize = $_FILES['car_image']['size'];


        if(empty($carname)){
            $errMSG = "Please Enter Name of the Car.";
        }
        else if(empty($carmodel)){
            $errMSG = "Please Enter Model Number of the car.";
        }
        else if(empty($caramount)){
            $errMSG = "Please Enter the cost of the car.";
        }
        else if(empty($imgFile)){
            $errMSG = "Please Select Image File.";
        }
        else
        {

            $upload_dir = 'user_images/'; // upload directory

            $imgExt = strtolower(pathinfo($imgFile,PATHINFO_EXTENSION)); // get image extension

            // valid image extensions
            $valid_extensions = array('jpeg', 'jpg', 'png', 'gif'); // valid extensions

            // rename uploading image
            $carpic = rand(1000,1000000).".".$imgExt;

            // allow valid image file formats
            if(in_array($imgExt, $valid_extensions)){            
                // Check file size '5MB'
                if($imgSize < 5000000)                {
                    move_uploaded_file($tmp_dir,$upload_dir.$carpic);
                }
                else{
                    $errMSG = "Sorry, your file is too large.";
                }
            }
            else{
                $errMSG = "Sorry, only JPG, JPEG, PNG & GIF files are allowed.";        
            }
        }


        // if no error occured, continue ....
        if(!isset($errMSG))
        {
            $stmt = $DB_con->prepare('INSERT INTO tbl_cars(carName,carModel,carAmount,carPic) VALUES(:cname, :cmodel, :camount, :cpic)');
            $stmt->bindParam(':cname',$carname);
            $stmt->bindParam(':cmodel',$carmodel);
            $stmt->bindParam(':camount',$caramount);
            $stmt->bindParam(':cpic',$carpic);
            if($stmt->execute())
            {
                $successMSG = "new record succesfully inserted ...";
                header("refresh:5;car_display.php"); // redirects image view page after 5 seconds.
            }
            else
            {
                $errMSG = "error while inserting....";
            }
        }
    }
?>

我知道我需要为每个循环添加一个简单的,执行失败了。 有人救了我

这是上传的HTML位

 <tr>
        <td><label class="control-label">Car Img.</label></td>
        <td><input class="input-group" type="file" name="car_image" multiple="multiple" accept="image/*" /></td>

1 个答案:

答案 0 :(得分:0)

你需要在html中指定它是一个文件数组 然后在你的php中调用foreach,基本上post将是一个数组。

我的示例不使用PDO或适用于您的示例,但它正在上传多个文件。

PHP:

<?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';
        }       
        $query="INSERT into upload_data (`USER_ID`,`FILE_NAME`,`FILE_SIZE`,`FILE_TYPE`) VALUES('$user_id','$file_name','$file_size','$file_type'); ";
        $desired_dir="user_data";
        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,"user_data/".$file_name);
            }else{                                  //rename the file if another one exist
                $new_dir="user_data/".$file_name.time();
                 rename($file_tmp,$new_dir) ;               
            }
            mysql_query($query);            
        }else{
                print_r($errors);
        }
    }
    if(empty($error)){
        echo "Success";
    }
}
?>

HTML

<form action="yourphpfile.php" method="POST" enctype="multipart/form-data">
    <input type="file" name="files[]" multiple="" />
    <input type="submit"/>
</form>