PHP mkdir失败没有错误

时间:2013-03-26 01:22:45

标签: php upload mkdir

我正在尝试在我家的本地网络上设置一个小型文件共享服务器,并且遇到了上传者的一些大问题。它似乎失败的步骤是目录创建步骤,但是,当我第一次发布它时,Apache日志文件中没有错误,但结果是滞后文件的权限问题的结果。

这是相关的日志条目。

[Mon Mar 25 18:43:05 2013] [error] [client 10.0.0.17] PHP Warning:  mkdir(): Permission denied in /server/upload_movie.php on line 10, referer: http://10.0.0.17/upload_movie.html
因为我跑了,所以让我感到困惑 sudo chmod 0777 / server / * sudo chmod 0777 / server / server /是rood目录。

我的代码如下

<?php
echo "starting". "<br>";
$allowedExts = array("mp4", "mpg", "avi", "mkv");
$extension = end(explode(".", $_FILES["uplodedfile"]["name"]));
echo "filetype parsed". "<br>";
$path = "/downloads/movies/unsorted/";
echo "checking upload directory". "<br>";
if(!is_dir($path)){
    echo "upload directory not found, creating...";
    if (mkdir($path,0777,true))
        {
        echo "directory creation complete". "<br>";
        }
    else
        {
        echo "directory creation failed at ".$path."<br>";
        }
}
echo "checking file". "<br>";
if (false)
  {
  echo "filetype and size passed". "<br>";
  if ($_FILES["uplodedfile"]["error"] > 0)
    {
    header('Location:  upload_failure.php?file='.$_FILES["uplodedfile"]['name'].'&error='.$_FILES["uplodedfile"]["error"]);
    exit();
    }
  else
    {
    echo "Upload: " . $_FILES["file"]["name"] . "<br>";
    echo "Type: " . $_FILES["file"]["type"] . "<br>";
    echo "Size: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
    echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br>";

    if (file_exists("upload/" . $_FILES["uplodedfile"]["name"]))
      {
       echo $_FILES["file"]["name"] . " already exists on server. ". "<br>";
      }
    else
      {
      echo "creating perminant copy of file". "<br>";
      move_uploaded_file($_FILES["uplodedfile"]["tmp_name"],
      $path."/" . $_FILES["uplodedfile"]["name"]);
      echo "Stored in: " . "movie_uploads/" . $_FILES["file"]["name"]. "<br>";
      }
    }
    header('Location:  upload_success.php?type=movie');
    exit();
  }
else
  {
  echo "error:<br>";
  echo "Type: " . $_FILES["file"]["type"] . "<br>";
  echo "Name: " . $_FILES["file"]["name"] . "<br>";
  echo "Size: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
  echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br>";
  echo "extension: ".$extension;
  exit();
  // echo "Invalid file";
  }
?>

输出如下

starting
filetype parsed
checking upload directory
upload directory not found, creating...directory creation failed at /downloads/movies/unsorted/
checking file
error:
Type: 
Name: 
Size: 0 kB
Temp file: 
extension:

并且调用它的代码是

<form enctype="multipart/form-data" action="upload_movie.php" method="POST">
<input name="uploadedfile" type="file" /><br />
<input type="submit" value="Upload File" />
</form>

我已经尝试了PHP mkdir: Permission denied problem中的所有建议,并关闭了selinux。我正在使用fedora 17.服务器正在ext4分区上运行,其中不包含任何其他内容。

正如评论中所建议的那样,我试过了         $ error = error_get_last(); echo $ error [&#39; message&#39;]; 哪个是...         未定义的索引:文件

2 个答案:

答案 0 :(得分:0)

您似乎已为/ server-directory设置了正确的权限。但是您的服务器想要写入/ downloads-目录。您应该启动并运行此命令:

Sudo chmod 777 /download

答案 1 :(得分:0)

您的错误消息会告诉其中的所有内容。这是文件写入权限问题。如果要在/ downloads / movies / unsorted /中编写文件,则需要为所有人设置此目录的写权限(777)。但是你说,你已经检查了下载目录的权限,但是你可能没有设置重复目录的权限。所以在上传文件之前请尝试以下命令。

Sudo chmod -R 777 /download