Php 如何替换codeigniter中的数据库配置?

Php 如何替换codeigniter中的数据库配置?,php,codeigniter,Php,Codeigniter,我已经为我的网站安装了一个安装程序。但是我不知道如何替换主机名,用户名,密码和数据库。使用来自输入字段的值。 这是config/database.php文件中的代码 $db['default'] = array( 'dsn' => '', 'hostname' => 'db_host', 'username' => 'db_user', 'password' => 'db_pass', 'database' => 'db_

我已经为我的网站安装了一个安装程序。但是我不知道如何替换
主机名
用户名
密码
数据库
。使用来自输入字段的值。 这是
config/database.php
文件中的代码

$db['default'] = array(
    'dsn'   => '',
    'hostname' => 'db_host',
    'username' => 'db_user',
    'password' => 'db_pass',
    'database' => 'db_name',
    'dbdriver' => 'mysqli',
    'dbprefix' => '',
    'pconnect' => FALSE,
    'db_debug' => (ENVIRONMENT !== 'production'),
    'cache_on' => FALSE,
    'cachedir' => '',
    'char_set' => 'utf8',
    'dbcollat' => 'utf8_general_ci',
    'swap_pre' => '',
    'encrypt' => FALSE,
    'compress' => FALSE,
    'stricton' => FALSE,
    'failover' => array(),
    'save_queries' => TRUE
);
但是这个代码给了我这个错误

控制器
中输入此代码

function configure_database() {
    // write database.php
    $data_db = file_get_contents('./application/config/database.php');
   // session_start();
    $data_db = str_replace('db_name',   $_POST['dbname'],   $data_db);
    $data_db = str_replace('db_user',   $_POST['username'], $data_db);
    $data_db = str_replace('db_pass',   $_POST['password'], $data_db);
    $data_db = str_replace('db_host',   $_POST['hostname'], $data_db);
    file_put_contents('./application/config/database.php', $data_db);
  }
如果要动态设置配置项或更改现有配置项,可以使用:

$this->config->set_item('item_name','item_value')

其中项目名称为 要更改的$config数组索引,而item_值是它的 价值观

所以你可以试试这个:

 // validate the input
 if(isset($_POST['dbname']){
     $this->config->set_item('hostname',$_POST['dbname']);
 }
 ...

您可以按如下方式格式化
config/database.php

$db['default']['username'] = "%USERNAME%";
$db['default']['password'] = "%PASSWORD%";
$db['default']['database'] = "%DATABASE%";
$db['default']['hostname'] = "%HOSTNAME%";
$db['default']['dbdriver'] = "mysqli";
$db['default']['dbprefix'] = "";
$db['default']['pconnect'] = TRUE;
$db['default']['db_debug'] = TRUE;
$db['default']['cache_on'] = FALSE;
$db['default']['cachedir'] = "";
$db['default']['char_set'] = "utf8";
$db['default']['dbcollat'] = "utf8_general_ci";
然后使用以下方法写入:

function configure_database() {
    // write database.php
    $data_db = file_get_contents('config/database.php');
    // session_start();
    $temporary = str_replace("%DATABASE%", $_POST['dbname'],   $data_db);
    $temporary = str_replace("%USERNAME%", $_POST['username'], $temporary);
    $temporary = str_replace("%PASSWORD%", $_POST['password'], $temporary);
    $temporary = str_replace("%HOSTNAME%", $_POST['hostname'], $temporary);
    // Write the new database.php file
    $output_path = './application/config/database.php';
    $handle = fopen($output_path,'w+');
    // Chmod the file, in case the user forgot
    @chmod($output_path,0777);
    // Verify file permissions
    if(is_writable($output_path)) {
        // Write the file
        if(fwrite($handle,$temporary)) {
            return true;
        } else {
            return false;
        }
    } else {
        return false;
    }
}
基本上,它检查每一行是否匹配,然后用发布的数据替换它们,最后再次将其写入数据库配置

参考: