發現問題
在 Laravel 項目中,如果執行了 php artisan config:cache
命令把配置文件緩存起來後,在 Tinker 中(Tinker 是 Laravel 自帶的一個交互式命令行界面),使用 env
函數讀取環境變量的值為 null
,只有執行 php artisan config:clear
清除配置緩存後就可以讀取了,這是為什麼呢?
一探究竟
打開 .env 文件看,這些都是有值的:
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
:
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
函數讀取。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。