问题:
如何在 session 变量中更新更改后的用户名而不注销或 session 销毁?
例如:
我使用用户名“Ram”登录,该用户名存储在 session 变量 User_Name 中,登录后我将用户名“Ram”更改为“Kumar”。因此,这个新更改的用户名应该在 session 变量 User_Name 中自动更新,而无需从我的帐户注销。
登录 Controller 代码示例:
function check_database($password)
{
// Field validation succeeded. Validate against database
$username = $this->input->post('username');
// query the database
$result = $this->civic_soft_model->login($username, $password);
if($result)
{
$sess_array = array();
foreach($result as $row)
{
$sess_array = array(
'UID' => $row->UID,
'User_Name' => $row->User_Name,
'User_Type' => $row->User_Type,
'User_OTP' => $row->User_OTP
// 'Login_Status' => $row->Login_Status
// 'Node_Id' => $row->Node_Id
);
$this->session->set_userdata('logged_in', $sess_array);
}
return TRUE;
}
else
{
$this->form_validation->set_message('check_database', 'Invalid username or password');
return false;
}
}
注意:
我正在使用 PHP、MySQL 和 CodeIgniter MVC 框架。
请 friend 们帮助我...
最佳答案
我现在确实明白问题所在了。您将“logged_in”设置为一个数组。不确定这是否常见,但我通常所做的是将“logged_in”设置为 bool 值,然后将 userdata 设置为另一个数组中我需要的数据。
但是,对于您的情况,您可以尝试以下操作:
$newUserData = $this->session->userdata('logged_in');
if (is_array($newUserData)) {
$newUserData['User_Name'] = $new_username;
$this->session->set_userdata('logged_in', $newUserData);
}
为了更好的可用性,我会向 $this->civic_soft_model
添加一个名为“updateUser”或类似性质的函数。当调用该函数时,您可以更新所需的所有 session 数据。
关于mysql - 如何在 session 变量中更新更改的用户名而不注销或 session 销毁,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22768410/