大家好我有两个在codeigniter中开发的网站。这些网站是完全不同的,但用户的mdoel类似于登录方法,因为我想回收该代码。 问题是:如果我登录到一个站点并打开另一个站点,我将与其他站点的用户一起登录到我的数据库中。 数据库是不同的,我不知道是什么问题,或者我是否必须将我的登录方法更改为我的模型或某些配置。
这是我在模型中的方法:
function login($username = '', $password = '') {
$user_name = base64_decode($username);
$password = base64_decode($password);
//Make sure login info was sent
if($username == '' || $password == '') {
return FALSE;
}
//Check if already logged in
if( $this->session->userdata('username') == $username && $this->session->userdata('logged_in') ) {
//User is already logged in.
return TRUE;
}
//Check against user table
$this->db->where('username', $user_name);
$this->db->where('password', $this->encrypt->sha1($password) );
$this->db->where('active', 1);
$query = $this->db->get_where($this->user_table);
if ($query->num_rows() > 0) {
$row = $query->row_array();
//Destroy old session
$this->session->sess_destroy();
//Create a fresh, brand new session
$this->session->sess_create();
//Update Last Login
$data = array(
'last_login' => date('Y-m-d H:i:s')
);
$this->db->where('id', $row['id']);
$this->db->update($this->user_table, $data);
//Set session data
$this->session->set_userdata(array('id' => $row['id'], 'username' => $row['username'],'name' => $row['name'], 'surname' => $row['surname'], 'language' => $row['language']));
if ($row['type']==1){
//se è 1 è un administrator
$this->session->set_userdata(array('is_admin' => 1));
}
else{
$this->session->set_userdata(array('is_admin' => 0));
}
//Set logged_in to true
$this->session->set_userdata(array('logged_in' => TRUE));
//image profile
$this->db->where('user_id', $row['id']);
$query2 = $this->db->get_where('user_image_profile');
if ($query2->num_rows() > 0) {
$row_image = $query2->row_array();
$this->session->set_userdata(array('img_profile' => $row_image['filename']));
}
//Login was successful
return TRUE;
} else {
//No database result found
return FALSE;
}
}
答案 0 :(得分:1)
我认为问题出在config
文件中。因此,当您登录一个站点并在此处打开另一个站点时,您同时为这两个站点使用相同的“encryption_key”。因此,您必须为这两个站点使用不同的“encryption_key”。
$config['encryption_key'] = 'gHZc2let11sp3YAns00rggHlYNMp7CVX';
和第二个 -
$config['encryption_key'] = 'V1M839GlUk65rKzm1GM67H66X1WLD6ay';
答案 1 :(得分:0)
对于每个应用程序,您可以配置要存储在数据库中的会话。更改配置文件。
sess_use_database = true;
之后,您需要在数据库中创建此表
CREATE TABLE IF NOT EXISTS `ci_sessions` (
session_id VARCHAR(40) DEFAULT '0' NOT NULL,
ip_address VARCHAR(16) DEFAULT '0' NOT NULL,
user_agent VARCHAR(120) NOT NULL,
last_activity INT(10) UNSIGNED DEFAULT 0 NOT NULL,
user_data TEXT NOT NULL,
PRIMARY KEY (session_id),
KEY `last_activity_idx` (`last_activity`)
);