У меня проблемы с загрузкой файла из PHP на Centos 7.0 Apache Server
КОД PHP
<html>
<head>
<title>Upload your files</title>
</head>
<body>
<form enctype="multipart/form-data" action="index.php" method="POST">
<p>Upload your file</p>
<input type="file" name="uploaded_file"></input><br />
<input type="submit" value="Upload"></input>
</form>
</body>
</html>
<?PHP
if(!empty($_FILES['uploaded_file']))
{
$path = "/var/www/html/";
$path = $path . basename( $_FILES['uploaded_file']['name']);
if(move_uploaded_file($_FILES['uploaded_file']['tmp_name'], $path)) {
echo "The file ". basename( $_FILES['uploaded_file']['name']).
" has been uploaded";
} else{
echo "There was an error uploading the file, please try again!";
}
}
?>
Обратите внимание, что file_uploads включен в php.ini
и папка "/ var / www / html /" имеет разрешение 0777, и ее владельцем является apache
Я перепробовал почти все решения в stackoverflow,
chmod -R 0777 /var/www/html
chown apache /var/www/html
find /var/www/html/ -type f -print0 | xargs -0 chmod -v 777
Тем не менее загрузка файла не удалась,и получил эту ошибку в HTTPD error_log
[Tue Mar 19 10:34:21.257969 2019] [:error] [pid 27446] [client 172.20.20.41:61798] PHP Warning: move_uploaded_file(/var/www/html/Scan.pdf): failed to open stream: Permission denied in /var/www/html/index.php on line 23, referer: http://10.104.25.70/index.php
[Tue Mar 19 10:34:21.258095 2019] [:error] [pid 27446] [client 172.20.20.41:61798] PHP Warning: move_uploaded_file(): Unable to move '/tmp/php64POiK' to '/var/www/html/Scan.pdf' in /var/www/html/index.php on line 23, referer: http://10.104.25.70/index.php
вывод
ls -l
равен
drwxrwxrwx. 3 apache root 34 Mar 18 13:24 html
вывод
stat html
1026 *