Amazon Web Services, versão do servidor: Apache/2.4.6 (Red Hat Enterprise Linux)
O log do apache relata:
[Fri Aug 07 13:53:40.793562 2015] [:error] [pid 10730] [client 149.88.114.40:40800] PHP Warning: file_put_contents(./test.txt): failed to open stream: Permission denied in /var/www/html/vraim/index.php on line 18
Aqui está o código PHP que tenta gravar no diretório atual:
<?php
file_put_contents("./test.txt", "Test"); // <=== This cannot write!!!
$uid = posix_getuid();
echo "PosixGetUID: " . $uid . "<br/>";
$userinfo = posix_getpwuid($uid);
print_r($userinfo);
?>
As permissões no diretório:
# namei -movl /var/www/html/vraim/
f: /var/www/html/vraim/
dr-xr-xr-x root root /
drwxr-xr-x root root var
drwxr-xr-x root root www
drwxr-xr-x apache root html
drwxrwxrwx apache root vraim
O httpd.conf para o host virtual:
DocumentRoot /var/www/html/vraim
<Directory />
Require all granted
</Directory>
O que eu faço de errado? Por que o PHP não pode gravar na pasta que pertence ao Apache?
O próprio script PHP gera as seguintes informações sobre seu ID de usuário efetivo:
PosixGetUID: 48
Array ( [name] => apache [passwd] => x [uid] => 48 [gid] => 48 [gecos] => Apache [dir] => /usr/share/httpd [shell] => /sbin/nologin )
pode vir do selinux, tente defini-lo como permissivo para verificar:
isso pode acontecer quando você move algo de um lugar para outro. Ele preserva o contexto selinux do original quando você o move