我正在尝试在php中创建一个文件夹,并且每个用/tmp/...
作为路径的代码都失败了:
exec("mkdir -p /tmp/test/ 2>&1", $output, $return_code);
// $output is empty, $return_code is 0
//mkdir("/tmp/test/"); // Alternative to above
is_dir("/tmp/test/"); // returns true
is_readable("/tmp/test/"); // returns true
但是如果我检查/tmp
- 文件夹没有这样的目录,并且该文件夹上的所有后续写入或读取操作都会失败,因为该文件夹不存在。 /tmp
的权限是正确的(root:root with 777),我可以sudo -u http mkdir -p /tmp/test
没有问题。例如,如果我使用tmp/test
,代码将运行正常并在php-skript的目录中创建一个文件夹(位于属于我的文件夹中,而不是http用户...)
关于为什么php无法在/tmp/
下创建文件夹但是将其报告为存在的任何想法?
编辑: 指定读取和写入操作:这些操作不是来自我自己的脚本,而是来自外部skripts,由php脚本调用以执行不同的任务。一旦所有这些文件成功完成,文件夹就会被压缩并复制到其他地方。
编辑:
运行exec("mkdir -p /tmp/testfolder");
后立即
[daishy@littlezombie tmp]$ pwd
/tmp
[daishy@littlezombie tmp]$ ls -al
insgesamt 8
drwxrwxrwt 21 root root 440 3. Aug 18:56 .
drwxr-xr-x 20 root root 4096 10. Jun 16:49 ..
drwxrwxrwt 2 root root 40 3. Aug 09:42 .font-unix
drwxr-xr-x 2 daishy users 60 3. Aug 14:40 hsperfdata_daishy
drwxrwxrwt 2 root root 60 3. Aug 09:42 .ICE-unix
drwx------ 2 daishy users 60 3. Aug 12:35 kde-daishy
drwx------ 2 daishy users 140 3. Aug 18:49 ksocket-daishy
drwx------ 3 root root 60 3. Aug 18:54 systemd-private-5rIfGj
drwx------ 3 root root 60 3. Aug 09:42 systemd-private-HGNW9x
drwx------ 3 root root 60 3. Aug 09:42 systemd-private-od4pyY
drwx------ 3 root root 60 3. Aug 09:42 systemd-private-qAH8UK
drwxrwxrwt 2 root root 40 3. Aug 09:42 .Test-unix
drwx------ 4 daishy users 80 3. Aug 16:55 .Trash-1000
-r--r--r-- 1 root root 11 3. Aug 09:42 .X0-lock
drwxrwxrwt 2 root root 60 3. Aug 09:42 .X11-unix
drwxrwxrwt 2 root root 40 3. Aug 09:42 .XIM-unix
编辑:
事实证明,这不是php的问题,而是systemd / apache。简而言之:systemd在运行时为apache创建一个私有tmp文件夹,它位于/ tmp / systemd-private-XYZ下。所以真正的/tmp
不是由php-skript可见的,而是私有的。{{1}}。
有关更多信息,请参阅http://blog.oddbit.com/post/private-tmp-directories-in-fedora。
答案 0 :(得分:6)
事实证明,这不是php的问题,而是systemd / apache。简而言之:systemd在运行时为apache创建一个私有tmp文件夹,它位于/ tmp / systemd-private-XYZ下。所以真正的/ tmp不是由php-skript可见的,而是私有的。
要禁用此行为,您可以在/usr/lib/systemd/system/httpd.service
中设置 PrivateTmp = false有关更多信息,请参阅http://blog.oddbit.com/2012/11/05/fedora-private-tmp/。
答案 1 :(得分:2)
不要那样做。使用PHP的名为function, tmpfile()
。来自文档:
$temp = tmpfile();
fwrite($temp, "writing to tempfile");
fseek($temp, 0);
echo fread($temp, 1024);
fclose($temp); // this removes the file