2013-03-26 185 views
1

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

这是相关的日志条目。

[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 

它混淆了我,因为我已经运行 须藤chmod为0777 /服务器/ * 须藤chmod为0777 /服务器 与/服务器/是圣坛目录。

我的代码如下

<?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 ['message']; 哪些是yealded 未定义的索引:文件

+0

您是否启用了'error_reporting'?应该有一条消息,除非你的'/'根目录是世界可写的。 (不,不这样做!) – mario 2013-03-26 01:24:54

+0

添加这个来得到错误是什么,它似乎是一种权限问题,任何方式尝试代码来获取错误代码:$ error = error_get_last(); echo $ error ['message']; – 2013-03-26 01:26:24

+0

马里奥是正确的,你应该或应该说,必须检查你的目录的权限。 – 2013-03-26 01:26:47

回答

0

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

Sudo chmod 777 /download 
0

您的错误消息告诉它的一切。这是文件写入权限问题。如果你想将你的文件写入/ downloads/movies/unsorted /那么你需要为这个目录设置写入权限(777)。但是您说,您已经检查了下载目录的权限,但是您可能未设置对重复目录的权限。所以请在上传文件之前尝试下面的命令。

Sudo chmod -R 777 /download