事实上,我是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存储根本没有帮助。
您可能已经知道,这个问题是由于没有对日志文件夹(存储的子文件夹)的写权限引起的。
要解决这个问题,需要经过以下一系列步骤
更新的作曲家
sudo composer self-update
修改存储文件夹写权限
sudo chmod -R ugo+rw storage
现在存储文件夹应该有权限drwxrwxrwx
从项目根运行以下命令检查权限
ls -l
同样,如果您在上述步骤后遇到以下错误
ErrorException chdir(): No such file or directory (errno 2)
只需在项目根文件夹中使用创建一个名为public的文件夹
sudo mkdir public
关于chmod命令的更多信息,请检查这个
对于所有在Laravel环境下的Centos 7用户,不需要禁用Selinux,只需要运行这些命令:
yum install policycoreutils-python -y # might not be necessary, try the below first
semanage fcontext -a -t httpd_sys_rw_content_t "/var/www/html/laravel/storage(/.*)?" # add a new httpd read write content to sellinux for the specific folder, -m for modify
semanage fcontext -a -t httpd_sys_rw_content_t "/var/www/html/laravel/bootstrap/cache(/.*)?" # same as the above for b/cache
restorecon -Rv /var/www/html/ # this command is very important to, it's like a restart to apply the new rules
最后,确保您的主机、ip和虚拟主机都正确用于远程访问。
Selinux的目的是限制对根用户的访问,所以只有必要的东西可以访问,至少从一般的概述来看,它是额外的安全,禁用它不是一个好的实践,有许多学习Selinux的链接,但在这种情况下甚至不需要它。