PHP mkdir():权限被拒绝

时间:2018-11-07 08:41:25

标签: php mysql permissions mkdir denied

我有一个简单的PHP / HTML / CSS应用程序,可以为新注册的用户创建一个文件夹。它在我的测试站点上工作得很好,并不是说我已经准备好“上线”,但我收到“ mkdir():权限被拒绝”错误。据我所知,两个站点上的所有设置都相同,并且root和uploads文件夹的文件许可权设置为755。其他所有工作都按预期方式接受,下面的代码...

if (count($errors) == 0) {
        $pword = md5($pword_1);//encrypt the pword before saving in the database
        $rand = "ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890abcdefghijklmnopqrstuvwxyz";
        $rand = str_shuffle($rand);
        $folder = substr($rand, 0, 10);
        $regDate = date("Y-m-d");
        $token = 0;
        $tokenExp = 0;
        $curDir = getcwd();

        if(mkdir($curDir . "/uploads/" . $folder, 0755)){
            $query = "INSERT INTO users (uname, email, pword, folder, regDate, token, tokenExp) VALUES ('$uname', '$email', '$pword', '$folder', '$regDate', '$token', '$tokenExp')";
            mysqli_query($db, $query);
            $_SESSION['uname'] = $uname;
            $_SESSION['success'] = "You are now logged in";
            header('location: index.php');
        }else{
            array_push($errors, "An error occurred creating your account!!!");
        }
    }

据我所知无法创建用户的文件夹,我无法上传文件。但是,在进行故障排除时,当我手动将文件夹添加到服务器时,仍然出现“找不到路径”错误。这是上传文件的代码...

if(isset($_POST['uploads'])){
    $uname = mysqli_real_escape_string($db, $_POST['uname']);
    $name = $_FILES['file']['name'];
    $size = $_FILES['file']['size'];
    $type = $_FILES['file']['type'];
    $tmp_name = $_FILES['file']['tmp_name'];
    $extension = substr($name, strpos($name, '.') + 1);
    $max_size = 2500000; //bytes

    if(empty($name)) {
        echo "<p class='error'>Please Select a File</p>";
    }else{
        if($extension == "jpg" || $extension == "jpeg" || $extension == "gif" || $extension == "tif" || $extension == "png" || $extension == "pdf"){
            if($extension == $size<=$max_size){
                $getFold = "SELECT * FROM users WHERE uname='$uname'";
                $getFold = mysqli_query($db, $getFold);
                while($for = mysqli_fetch_assoc($getFold)){
                    $folder = $for['folder'];
                }
                $location = "uploads/" . $folder . "/";
                if(move_uploaded_file($tmp_name, $location . $name)){
                    $query = "INSERT INTO `upload` (name, size, type, location, uname, folder) VALUES ('$name', '$size', '$type', '$location', '$uname', '$folder')";
                    $result = mysqli_query($db, $query);
                    if($result){
                        echo "<p class='success'>File has been uploaded successfully!!!</p>";
                    }else{
                        echo "<p class='error'>Failed to upload file information to database!!! Filename already exist!</p>";
                    }               
                }else{
                    echo "<p class='error'>Failed to Upload File</p>";
                }
            }else{
                echo "<p class='error'>File size should be 3MB or less</p>";
            }
        }else{
            echo "<p class='error'>The selected file is not a JPG, JPEG, GIF, TIF, PNG, or PDF file type!!!</p>";
        }
    }
}

3 个答案:

答案 0 :(得分:0)

您使用权限0755创建目录,这意味着所有者具有完全访问权限,而其他用户则只能读取+执行。将其更改为07770766;拥有对所有人的完全访问权或对所有者的完全访问权,并且可以对任何人进行读写操作。
这也适用于父文件夹。

答案 1 :(得分:0)

您需要将您要为用户创建子文件夹的文件夹的所有者更改为:

  1. apache-对于CentOS服务器
  2. www-data-对于Ubuntu服务器

您可以使用以下命令进行操作

sudo chown -R www-data /folder

-R标志意味着它是递归的,因此运行php的apache / httpd进程将拥有您可能已经创建的所有子文件夹。

有关此命令的更多信息,请查看此SO post

答案 2 :(得分:0)

谢谢您的帮助,我听从了您的建议,结果发现,我的主机提供商在cPanel可访问的晦涩“设置”位置阻止了该功能。以前(即在我较旧的测试服务器/帐户上),帐户是自动设置为允许读/写访问的,新帐户被设置为只读,并且要求帐户所有者通过设置进行切换。< / p>