我试图在我家的本地网络上建立一个小型文件共享服务器,并遇到了上传者的一些大问题。它似乎失败的一步是目录创建步骤,但是,当我第一次发布时,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 未定义的索引:文件
您是否启用了'error_reporting'?应该有一条消息,除非你的'/'根目录是世界可写的。 (不,不这样做!) – mario 2013-03-26 01:24:54
添加这个来得到错误是什么,它似乎是一种权限问题,任何方式尝试代码来获取错误代码:$ error = error_get_last(); echo $ error ['message']; – 2013-03-26 01:26:24
马里奥是正确的,你应该或应该说,必须检查你的目录的权限。 – 2013-03-26 01:26:47