探究Laravel使用env函数读取环境变量为null的问题

时间:2021-07-22 15:56:45

发现问题

在 laravel 项目中,如果执行了 php artisan config:cache 命令把配置文件缓存起来后,在 tinker 中(tinker 是 laravel 自带的一个交互式命令行界面),使用 env 函数读取环境变量的值为 null,只有执行 php artisan config:clear 清除配置缓存后就可以读取了,这是为什么呢?

一探究竟

打开 .env 文件看,这些都是有值的:

?
1
2
3
4
5
6
7
8
9
10
11
12
app_env=local
app_key=base64:jhe5bokrg283ut0n1zq/ggvgeer8ooyib42/wiccyvo=
app_debug=true
app_log_level=debug
app_url=http://www.tanteng.me
 
db_connection=mysql
db_host=127.0.0.1
db_port=3306
db_database=tanteng.me
db_username=homestead
db_password=secret

如图所示:

探究Laravel使用env函数读取环境变量为null的问题

原因何在?

在 laravel 中,如果执行 php aritisan config:cache 命令,laravel 将会把 app/config 目录下的所有配置文件“编译”整合成一个缓存配置文件到  bootstrap/cache/config.php,每个配置文件都可以通过 env 函数读取环境变量,这里是可以读取的。但是一旦有了这个缓存配置文件,在其他地方使用 env 函数是读取不到环境变量的,所以返回 null.

让我们看看这段代码,illuminate/foundation/bootstrap/detectenvironment.php line 18

?
1
2
3
4
5
6
7
8
9
10
11
12
public function bootstrap(application $app)
{
 if (! $app->configurationiscached()) {
 $this->checkforspecificenvironmentfile($app);
 
 try {
  (new dotenv($app->environmentpath(), $app->environmentfile()))->load();
 } catch (invalidpathexception $e) {
  //
 }
 }
}

这个方法在框架启动后就会运行,这段代码说明了如果存在缓存配置文件,就不会去设置环境变量了,配置都读缓存配置文件,而不会再读环境变量了。

因此,在配置文件即 app/config 目录下的其他地方,读取配置不要使用 env 函数去读环境变量,这样你一旦执行 php artisan config:cache 之后,env 函数就不起作用了。所有要用到的环境变量,在 app/config 目录的配置文件中通过 env 读取,其他地方要用到环境变量的都统一读配置文件而不是使用 env 函数读取。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。