gpt4 book ai didi

mysql - 如何在 session 变量中更新更改的用户名而不注销或 session 销毁

转载 作者:行者123 更新时间:2023-11-29 13:05:32 24 4
gpt4 key购买 nike

问题:

如何在 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com