發(fā)現(xiàn)問(wèn)題
在 Laravel 項(xiàng)目中,如果執(zhí)行了 php artisan config:cache 命令把配置文件緩存起來(lái)后,在 Tinker 中(Tinker 是 Laravel 自帶的一個(gè)交互式命令行界面),使用 env 函數(shù)讀取環(huán)境變量的值為 null,只有執(zhí)行 php artisan config:clear 清除配置緩存后就可以讀取了,這是為什么呢?
一探究竟
打開(kāi) .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 中,如果執(zhí)行 php aritisan config:cache 命令,Laravel 將會(huì)把 app/config 目錄下的所有配置文件“編譯”整合成一個(gè)緩存配置文件到 bootstrap/cache/config.php,每個(gè)配置文件都可以通過(guò) env 函數(shù)讀取環(huán)境變量,這里是可以讀取的。但是一旦有了這個(gè)緩存配置文件,在其他地方使用 env 函數(shù)是讀取不到環(huán)境變量的,所以返回 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) { // } } }
這個(gè)方法在框架啟動(dòng)后就會(huì)運(yùn)行,這段代碼說(shuō)明了如果存在緩存配置文件,就不會(huì)去設(shè)置環(huán)境變量了,配置都讀緩存配置文件,而不會(huì)再讀環(huán)境變量了。
因此,在配置文件即 app/config 目錄下的其他地方,讀取配置不要使用 env 函數(shù)去讀環(huán)境變量,這樣你一旦執(zhí)行 php artisan config:cache 之后,env 函數(shù)就不起作用了。所有要用到的環(huán)境變量,在 app/config 目錄的配置文件中通過(guò) env 讀取,其他地方要用到環(huán)境變量的都統(tǒng)一讀配置文件而不是使用 env 函數(shù)讀取。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。