所以我正在尝试通过HTML表单和简单的php脚本进行基本上传,但是move_uploaded_file函数总是返回false。我已经在目录上运行了"chmod 777"(当我实际使用它时,我会更多地处理安全性),并且"上传"目录位于htdocs文件夹中(实际上是Ubuntu服务器和Linux Mint中的/var/www)。
这是表格:
<html>
<body>
<form action="upload_file.php" method="post"
enctype="multipart/form-data">
<label for="file">Filename:</label>
<input type="file" name="file" id="file" />
<br />
<input type="submit" name="submit" value="Submit" />
</form>
</body>
</html>
。和upload_file.php...
<?php
if ($_FILES["file"]["error"] == 0){
if (file_exists("upload/" . $_FILES["file"]["name"])){
echo $_FILES["file"]["name"] . " already exists. ";
}else{
if(move_uploaded_file($_FILES["file"]["tmp_name"],"/var/www/upload/" . $_FILES["file"]["name"])){
echo "Stored in: " . "upload/" . $_FILES["file"]["name"];
}else{
echo "Failed to move uploaded file";
}
}
}else{
echo "Return Code: " . $_FILES["file"]["error"];
}
?>
当我尝试上传一个小的JPEG时,我得到"无法移动文件"。有什么想法吗?
您的脚本需要能够写入目标目录,在本例中为/var/www/upload/(这是您更改权限的目录吗?)。此外,您正在使用客户端的本地名称,这可能是一个可能的问题和安全问题(尽管不一定是这里的原因)。
当我发现我的操作系统是问题时,我想摧毁我的电脑。
chmod ugo+rwx yourfoldername
通过这种方式,您可以授予每个人写入/读取/删除文件夹的权限。