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

标签 mysql codeigniter

问题:

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

相关文章:

具有 2 个连接的 MySQL 查询,大 keylen 导致 'Copying to tmp table on disk' 进程永远挂起

sql 语句检索给定记录的结果列表(从其他表)?

mysql - Eloquent:检索带有垃圾条目的 pluck 集合

python - 优化创建/运行多个 SQLalchemy 引擎?

mysql - 如何将 'if clause' 放入 SQL 字符串中?

php - 如何在 codeigniter 的网站上进行信用卡支付

mysql - CodeIgniter:如何使用 WHERE 子句和 OR 子句

MySQL检查一个单词在表格单元格中出现了多少次

php - 一个 token 与多个 token 以防止 CSRF 攻击

php - Codeigniter 初始化()函数不工作