5

当我尝试通过某些函数访问任何目录或文件时,我在服务器上得到了一些有趣的结果。我已将所有文件和目录权限设置为 777,并将内容所有者更改为 Apache,但我仍然收到错误消息。代码:
move_uploaded_file($_FILES['file']['tmp_name'], '/var/www/html/fileContent_Site/userData/'.$_SESSION['username'].DIRECTORY_SEPARATOR.$_FILES['file']['name']);
或者 file_put_contents('userData/userData.txt', $result,FILE_APPEND); mkdir("userData/".$register['username']);

对于“move_uploaded_file()”,我得到:

move_uploaded_file(/var/www/php/Site/userData/radi/110729.png):无法打开流:/var/www/php/Site/upload.php 中的权限被拒绝

move_uploaded_file():无法将“/tmp/phpUFvMcn”移动到/var/www/php/Site/upload.php 中的“/var/www/php/Site/userData/radi/110729.png”

对于 'file_put_content()' 和 'mkdir()'

file_put_contents(userData/userData.txt):无法打开流:/var/www/php/Site/register.php 中的权限被拒绝

mkdir():/var/www/php/Site/register.php 中的权限被拒绝

4

3 回答 3

5
  1. 检查运行 PHP 的所有者。要检查 - 只需在 PHP 文件中的“file_put_contents”附近添加这些字符串

    echo "当前用户:".get_current_user();

    echo "脚本在用户下执行:".exec('whoami');

  2. 如果您看到当前用户和“脚本用户”之间的区别,那么您已经找到了问题所在。

输出示例:

current user: root
script was executed under user: www-data

只需将适当的用户设置为要从 PHP 脚本写入的 PHP 文件目录/目录: 在 Linux 终端中执行:

chown -R www-data:www-data /path/to/the/folder

请注意,“www-data”用户仅作为示例。您应该使用从“脚本在用户下执行”输出中获得的用户。

PS:要检查文件夹所有者,你可以使用这个 linux 命令:

ls -ltr

PPS:检查你的文件夹是否有正确的访问权限:755 文件夹php文件应该有“644”的访问权限。

要检查权限,请使用与所有者检查相同的命令:

ls -ltr

你会看到类似的东西:

drwxr-xr-x  10 www-data www-data 4096 Aug  5 15:18 api

其中“drwxr-xr-x”是访问权限。谷歌它,以获取更多信息。

于 2020-08-10T14:10:29.170 回答
0

利用

$_SERVER["DOCUMENT_ROOT"]."/myFolder/path to upload folder". 

并检查一次

于 2015-08-21T09:06:57.713 回答
0

打开 http.conf(在 /opt/lampp/etc/httpd.conf 中)文件。

编辑这部分:

<IfModule unixd_module>
#
# If you wish httpd to run as a different user or group, you must run
# httpd as root initially and it will switch.  
#
# User/Group: The name (or #number) of the user/group to run httpd as.
# It is usually good practice to create a dedicated user and group for
# running httpd, as with most system services.
#
User hostname
Group hostname
</IfModule>

看看,如果这行得通。

于 2015-08-21T09:15:08.610 回答