Проблема с разрешением загрузки PHP

у правых парней ive возникла проблема с разрешениями файлов со следующей формой загрузки. текстовый файл передается в файл upload / dir глобальными пользователями.

mysite$ ls -l drwxrwxrwx 2 user user 4096 2010-09-24 13:07 upload 

но поскольку я не зарегистрирован как root, новый файл, загруженный в домен, сохраненный в каталоге upload / dir с ограниченными разрешениями и не может быть изменен. например.

 upload$ ls -l -rw-r--r-- 1 www-data www-data 3067 2010-09-24 13:07 Readme.txt 

эта проблема, очевидно, одинакова для всех файлов, добавленных в папку загрузки глобальными пользователями. после загрузки файла мне нужен способ изменения прав на файл без внедрения корневого пароля в php-скрипт, запущенный в домене. пожалуйста помоги!

есть ли способ связать те же права на файлы, что и содержащая папка при добавлении новых файлов?

представить форму:

 <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"]["type"] == "text/plain") { if ($_FILES["file"]["error"] > 0) { echo "Return Code: " . $_FILES["file"]["error"] . "<br />"; } 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("/home/user/mysite/upload/" . $_FILES["file"]["name"])) { echo $_FILES["file"]["name"] . " already exists. "; } else { move_uploaded_file($_FILES["file"]["tmp_name"], "/home/user/mysite/upload/" . $_FILES["file"]["name"]); echo "Stored in: " . "upload/" . $_FILES["file"]["name"]; } } } else { echo "Invalid file"; } ?> 

Пользователь, который изначально записывает файлы в ваш каталог «/ upload», является тем, который запустил экземпляр Apache, который запускает PHP-модуль.

Другими словами, PHP является «владельцем» всех загруженных файлов, и через скрипт PHP вы можете изменять разрешения всех соответствующих загруженных файлов, не предоставляя никаких учетных данных вообще:

Функция PHP chmod

Быстрый и грязный взлом, позволяющий загружать файлы, доступные для записи всем пользователям, будет

 else { move_uploaded_file($_FILES["file"]["tmp_name"], $f="/home/user/mysite/upload/" . $_FILES["file"]["name"]); chmod($f, 0777); echo "Stored in: " . "upload/" . $_FILES["file"]["name"]; } 

move_uploaded_file использует umask (600). Используйте copy($source, $dest) вместо перемещения.

Вы можете использовать chmod для изменения прав доступа к файлам.

Чтобы получить права доступа к файлу, используйте fileperms .

если вы запускаете локальный сервер в Linux с помощью xampp или другим способом, существует очень ограниченное число. Поскольку локальный хост, созданный в корневом каталоге, например xampp, находится в (/ opt / lampp), если вы хотите удалить все ограничения, вставьте нижний код в терминал

 sudo chmod 777 /opt 

после этого

 sudo chmod 777 /opt/* 

после этого

 sudo chmod 777 /opt/*/* 

после этого

 sudo chmod 777 /opt/*/*/* 

и Продолжайте добавлять (/ *), пока не получите ошибку

удачи

in persian: وقتی یک سرور مجازی روی لینوکس راه اندازی میکنید محدودیت های زیادی دارید مثل آپلود فایل یا ساخت فایل و فولدر. برای برداشتن تمام تین محدودیت ها باید مسی اصلی سرور مجازی رو یدا کنید و دستورات زیر رو در ترمینال وارد کنید.

 sudo chmod 777 /opt 

بعد از آن

 sudo chmod 777 /opt/* 

بعد از آن

 sudo chmod 777 /opt/*/* 

بعد از آن

 sudo chmod 777 /opt/*/*/* 

و این کار را تا جایی که ارور دریافت کنید ادامه بدید. موفق باشید