警告:mkdir():文件存在

时间:2014-02-26 05:12:00

标签: php

传输到我的上传文件夹的文件运行良好,但我在 mkdir 中有警告。它说文件存在但图片和文件夹生成自己的名字。我不知道是什么警告决定的。

任何人都可以帮助我?

include('connect.php');

$dir=substr(uniqid(),-7); // Uniqid for subdirectory

$path = "uploads/$dir/"; // uploads/subdirectory/  // Make directory

$valid_formats = array("jpg", "png", "jpeg", "kml");

$max_file_size = 2097152;

$count = 0;


// Loop $_FILES to execute all files

 if(!empty($_FILES)){
foreach($_FILES['files']['name'] as $f => $name) {

    if ($_FILES['files']['error'][$f] == 4) {
        continue; // Skip file if any error found
    }  

    if ($_FILES['files']['error'][$f] == 0) {              
        if ($_FILES['files']['size'][$f] > $max_file_size) {
            $message[] = "$name is too large!.";
            continue; // Skip large files
        }

        elseif( ! in_array(pathinfo($name, PATHINFO_EXTENSION), $valid_formats) ){
            $message[] = "$name is not a valid format";
            continue; // Skip invalid file formats
        }

        else{ // No error found! Move uploaded files 
            mkdir($path, 0700);
            $ext = pathinfo($_FILES['files']['name'][$f], PATHINFO_EXTENSION);
            $uniq_name = substr(uniqid(),-5) . '.' .$ext;
            $dest = $path . $uniq_name;

            if(move_uploaded_file($_FILES["files"]["tmp_name"][$f], $dest)){

           $qry = "INSERT INTO files (code, name, path, type) VALUES ('$dir','$uniq_name','$dest','$ext')" ;

            $result = mysqli_query($dbc, $qry);
            if ( false===$result ) {
            $sql_error .= 'Error in the query '.$qry.'  Error Desc :'.mysqli_error($dbc).'<br /><br />' ;
                }
            }

        }

    }       
}}

2 个答案:

答案 0 :(得分:27)

警告很明显,您正在创建已存在的目录。所以,只需将其更改为

if (!file_exists($path)) {
    mkdir($path, 0700);
}

答案 1 :(得分:11)

使用PHP的is_dir($path_to_dir)检查以前是否存在目录。

Official documentation