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;
}
}
基本上,它检查每一行是否匹配,然后用发布的数据替换它们,最后再次将其写入数据库配置
参考: