у правых парней 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/*/*/*
و این کار را تا جایی که ارور دریافت کنید ادامه بدید. موفق باشید