【问题标题】:How can I get Laravel 4 environment variables to work?如何让 Laravel 4 环境变量工作?
【发布时间】:2014-08-18 06:38:29
【问题描述】:

我已经使用 laravel 创建了一个应用程序,并且我有一组环境我想像往常一样在该站点上运行。设置来自我声明环境的 start.php 文件,如下所示:

$env = $app->detectEnvironment(array(

    'local' => array('Mark-macbook.local'),
    'development' => array('excelsior.servers.prgn.misp.co.uk'),
    'production' => array('excelsior.servers.prgn.misp.co.uk'),

));

然后我在 server.php 所在的根目录中创建文件,并为每个环境创建具有正确数据库详细信息的文件,如下所示:

.env.local.php

<?php
return array(
    'DATABASE_HOST' => 'localhost',
    'DATABASE_NAME' => 'borough',
    'DATABASE_USER' => 'root',
    'DATABASE_PASSWORD' => 'root',
    'UNIX_SOCKET' => '/Applications/MAMP/tmp/mysql/mysql.sock'
);

.env.development.php

<?php
return array(
    'DATABASE_HOST' => 'localhost',
  'DATABASE_NAME' => 'db-name',
  'DATABASE_USER' => 'db-user',
  'DATABASE_PASSWORD' => 'pass'
);

.env.production.php

等等等等

然后在我的 app/config 中的 database.php 文件中,我有这个设置:

'connections' => array(

        'mysql' => array(
            'driver'    => 'mysql',
            'host'      => $_ENV['DATABASE_HOST'],
            'unix_socket'   => $_ENV['UNIX_SOCKET'],
            'database'  => $_ENV['DATABASE_NAME'],
            'username'  => $_ENV['DATABASE_USER'],
            'password'  => $_ENV['DATABASE_PASSWORD'],
            'charset'   => 'utf8',
            'collation' => 'utf8_unicode_ci',
            'prefix'    => '',
        ),

    ),

所以这是所有设置,因为我知道它通常可以工作,但是当我运行 php artisan serve 时,我收到了这个错误:

{"error":{"type":"ErrorException","message":"Undefined index: DATABASE_HOST","file":"\/Freelance\/Current Projects\/borough\/build\/borough-cc\/app\/config\/database.php","line":67}}

有谁知道为什么会发生这种情况以及我在这里可能做错了什么?

干杯

【问题讨论】:

    标签: php mysql laravel laravel-4 environment-variables


    【解决方案1】:

    凭记忆,由于我没有经常使用 Laravel,所以你没有正确使用它。

    基本上,数据库访问将在一种全局配置中查看配置键。此全局配置是 config 文件夹中的配置文件和环境配置组合的结果。

    因此,您只需要在环境配置中重新声明(或简单地声明)您的环境特定变量。

    .env.local.php

    <?php
        return array(
            'connections' => array(
                'mysql' => array(
                    'host'      => 'localhost',
                    'unix_socket'   => '/Applications/MAMP/tmp/mysql/mysql.sock',
                    'database'  => 'borough,
                    'username'  => 'root,
                    'password'  => 'root',
                ),
            ),
        ),
    );
    

    数据库.php

    'connections' => array(
        'mysql' => array(
            'driver'    => 'mysql',
            'charset'   => 'utf8',
            'collation' => 'utf8_unicode_ci',
            'prefix'    => '',
        ),
    ),
    

    在您的示例中,我有点担心您没有在两个配置中定义相同的键...基本上,您首先定义通用配置,然后在环境特定文件中重新定义您需要的任何内容。

    【讨论】:

      猜你喜欢
      • 2014-04-06
      • 1970-01-01
      • 1970-01-01
      • 2020-11-24
      • 2014-10-16
      • 2014-02-21
      • 2020-10-10
      • 2014-11-16
      • 2021-11-07
      相关资源
      最近更新 更多