首页 > 解决方案 > Drupal 8 Settings.php 中特定于环境的数据库连接配置

问题描述

我正在尝试将环境变量传递给Drupal中的数据库配置的settings.php文件,我能够访问环境变量并将它们存储到变量中,并将这些变量传递给settings.php中的数据库数组

如果我将数组打印到控制台,它打印得很好,但是在访问网站 Apache 日志时会出现以下错误

我尝试使用 getenv() 直接传递 env 变量 将 env 变量传递给另一个变量并将该新变量传递给数据库数组 将变量转换为 UTF-8 编码并将其传递给数据库数组

如果我对数据库配置值进行硬编码,它可以正常工作,但是当我尝试通过 env 变量读取它时它不起作用!我无法理解为什么当值通过似乎没问题时为什么不工作

错误日志堆栈

Drupal\\Core\\Database\\DatabaseAccessDeniedException: SQLSTATE[HY000] [1045] Access denied for user ''@'localhost' (using password: NO) in /var/www/html/core/lib/Drupal/Core/Database/Driver/mysql/Connection.php on line 427

Settings.php 中的代码

$vars = array(
  'DB_HOST',
  'DB_USERNAME',
  'DB_PASSWORD',
  'DB_PORT'
);
foreach($vars as $var) {
  if(!isset($_ENV[$var]) && getenv($var)){
    $_ENV[$var] = getenv($var);
  }
}

$username = mb_convert_encoding($_ENV['DB_USERNAME'], "UTF-8");
$password = mb_convert_encoding($_ENV['DB_PASSWORD'], "UTF-8");
$host = mb_convert_encoding($_ENV['DB_HOST'], "UTF-8");
$port = mb_convert_encoding($_ENV['DB_PORT'], "UTF-8");

$databases['default']['default'] = array (
  'database' => 'a_16a7f4a6-74a2-4066-aaa6-c0f4029f9a9f',
  'username' => $username,
  'password' => $password,
  'prefix' => '',
  'host' => $host,
  'port' => $port,
  'namespace' => 'Drupal\\Core\\Database\\Driver\\mysql',
  'driver' => 'mysql',
);
print_r($databases);

当我运行它显示的 php 文件时输出

Array
(
  [default] => Array
    (
        [default] => Array
            (
                [database] => a_16a7f4a6-74a2-4066-aaa6-c0f4029f9a9f
                [username] => root
                [password] => root
                [prefix] => 
                [host] => localhost
                [port] => 3306
                [namespace] => Drupal\Core\Database\Driver\mysql
                [driver] => mysql
            )

    )

)

标签: phpdrupal-8

解决方案


推荐阅读