事实上,我是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存储根本没有帮助。


当前回答

要解决这个问题,您需要将目录的所有权更改为web服务器使用的unix用户。

退出虚拟机 使用控制台,转到同步文件夹(vagrant) sudo chown -R $USER:www-data storage chmod -R 775存储

尽管我使用VM用户在VM中创建了项目,但文件夹属于真实计算机中的用户;所以,当你试着

现在起作用了。

感谢所有帮我找到答案的人

编辑:

实际上,它仍然不能工作,它仍然给了我一个“拒绝许可”的问题。

这是我所做的,我修改了我的Vagrantfile,像这样:

config.vm.synced_folder "./app","/var/www/", create:true,
:owner => "vagrant",
:group => "www-data",
:mount_options => ["dmode=775","fmode=664"]

其他回答

尝试了这里建议的任何方法都没有成功。

对我有用的是:

sudo chmod -R ugo+rw storage
sudo chmod -R ugo+rw storage/logs

需要调整存储和bootstrap/cache的权限。

cd到你的Laravel项目。 sudo chmod -R 755存储 sudo chmod -R 755 bootstrap/cache

如果755不行,你可以试试777。777可不安全!

根据您的web服务器的设置方式,您可以更具体地设置您的权限,并仅将它们授予您的web服务器用户。谷歌WEB SERVER NAME Laravel文件权限以获取更多信息。

在撰写本文时,这是针对Laravel 5.4的

要解决这个问题,您需要将目录的所有权更改为web服务器使用的unix用户。

退出虚拟机 使用控制台,转到同步文件夹(vagrant) sudo chown -R $USER:www-data storage chmod -R 775存储

尽管我使用VM用户在VM中创建了项目,但文件夹属于真实计算机中的用户;所以,当你试着

现在起作用了。

感谢所有帮我找到答案的人

编辑:

实际上,它仍然不能工作,它仍然给了我一个“拒绝许可”的问题。

这是我所做的,我修改了我的Vagrantfile,像这样:

config.vm.synced_folder "./app","/var/www/", create:true,
:owner => "vagrant",
:group => "www-data",
:mount_options => ["dmode=775","fmode=664"]

我在这个问题上尝试了不同的命令,但这些将有助于解决问题

php artisan route:clear
php artisan config:clear
php artisan cache:clear

希望这也能帮助到其他人。

在我的特殊情况下,我有一个配置文件生成并缓存到bootstrap/cache/目录,所以我的步骤如下:

删除所有生成的缓存文件:rm bootstrap/cache/*.php 创建一个新的laravelv .log文件,并使用以下方法更新该文件的权限: chmod -R 775存储