douli4337 2019-07-12 07:56
浏览 160
已采纳

无法读取环境变量

I have a simple Symfony project, using "symfony/dotenv": "4.3.*", in the composer.json and trying to read in the value of an environment variable.

This is my command:

var_dump($_ENV['MY_NEW_VAR']);

This is my .env file

MY_NEW_VAR=testing

Upon executing the command I get the following

string(7) "testing"

All good so far.... But now if I want to use environment variables to override the setting it returns an error. First I set the environment variable

export MY_NEW_VAR="something_else"

Then execute the command again, with the following results

[ErrorException]
Notice: Undefined index: MY_NEW_VAR

If I remove the environment variable using unset MY_NEW_VAR and execute the command again I get the value from the .env file

I would expect the environment variable to override the .env setting as explained in the comments of the .env file

# In all environments, the following files are loaded if they exist,
# the later taking precedence over the former:
#
#  * .env                contains default values for the environment variables needed by the app
#  * .env.local          uncommitted file with local overrides
#  * .env.$APP_ENV       committed environment-specific defaults
#  * .env.$APP_ENV.local uncommitted environment-specific overrides
#
# Real environment variables win over .env files.

Why does it not work with environment variables? Am I missing something?

  • 写回答

1条回答 默认 最新

  • duande8497 2019-07-12 08:34
    关注

    The code in your question is correct, so I'd wager the problem lies somewhere else.

    There are many vagaries and inconsistencies about how getenv(), $_ENV and $_SERVER work. I have found $_SERVER to be more reliable in my experience, and many times it safer to check both. E.g. if you check the code on config/bootstrap.php for Symfony 4.3 you'll see stuff like this:

    $_SERVER['APP_ENV'] = $_ENV['APP_ENV'] = ($_SERVER['APP_ENV'] ?? $_ENV['APP_ENV'] ?? null) ?: 'dev';
    

    In any case, if your $_ENV superglobal is initially empty, it could be because on the variables_order setting. Check its value, and if doesn't include an E, prepend it to the existing value and with that it should be populated correctly.

    The docs say that S is equivalent to ES...

    In both the CGI and FastCGI SAPIs, $_SERVER is also populated by values from the environment; S is always equivalent to ES regardless of the placement of E elsewhere in this directive.

    but I have not found it to be consistently so.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥15 想问一下树莓派接上显示屏后出现如图所示画面,是什么问题导致的
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化