發現問題
在 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 中,如果執行 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
函數讀取。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。