事实上,我是laravel的新手,我正在尝试创建我的第一个项目。出于某种原因,我一直得到这个错误(我甚至还没有开始编码)
Error in exception handler: The stream or file "/var/www/laravel/app/storage/logs/laravel.log" could not be opened: failed to open stream: Permission denied in /var/www/laravel/bootstrap/compiled.php:8423
我读到这与权限有关,但chmod -R 775存储根本没有帮助。
这可能有点晚了,但可能对某些人有帮助,更改目录权限对我有用。
假设你的Laravel项目在/var/www/html/目录下。转到这个目录。
cd /var/www/html/
然后修改存储/和引导/缓存/目录的权限。
sudo chmod -R 775 storage/
sudo chmod -R 775 bootstrap/cache/
如果权限775不生效,请尝试设置权限777。(警告!这是最宽松的许可,小心使用)。
sudo chmod -R 777 storage/
sudo chmod -R 777 bootstrap/cache/
cPanel:如果你在cPanel上,没有终端可用,你可以通过右键单击提到的目录和它的子目录来更改权限。
1-nginx用户和php-fpm用户、应用程序所有者用户必须相同:
执行命令sudo vi /etc/nginx/nginx.conf change,如下所示:
user nginx nginx;
执行命令sudo vi /etc/php-fpm.d/www.conf change,如下所示:
listen.owner = nginx
listen.group = nginx
listen.mode = 0660
user = nginx
group = nginx
然后重启nginx和php-fpm服务
运行以下命令
sudo chown nginx:nginx -R "your_project_path"
2-在项目路径下执行以下命令更改文件SELinux安全上下文
chcon -R -t httpd_sys_content_t .
chcon -R -t httpd_sys_rw_content_t .
在Laravel中,您应该在存储和缓存目录上设置ACL,以便web服务器用户可以对该目录进行读写。打开一个新终端,运行如下命令:
HTTPDUSER=$(ps axo user,comm | grep -E '[a]pache|[h]ttpd|[_]www|[w]ww-data|[n]ginx' | grep -v root | head -1 | cut -d\ -f1)
sudo setfacl -dR -m u:"$HTTPDUSER":rwX -m u:$(whoami):rwX bootstrap/cache storage/
sudo setfacl -R -m u:"$HTTPDUSER":rwX -m u:$(whoami):rwX bootstrap/cache storage/
引用:
https://symfony.com/doc/3.4/setup/file_permissions.html#using-acl-on-a-system-that-supports-setfacl-linux-bsd
https://linux.die.net/man/1/setfacl