Codeigniter - 将数据库结果存储在会话中

时间:2011-03-01 00:05:38

标签: php database session codeigniter login

嘿那里,我希望在登录时存储来自数据库查询的一些会话信息, 但由于某种原因,它不允许我设置会话userdata!?!

任何人都可以解释为什么?

控制器:

function validate_login(){
$this->load->library('form_validation');
$this->form_validation->set_rules('email_address', "Email address","required|valid_email");
$this->form_validation->set_rules('password', "Password", "trim|required|min_length[6]|max_length[32]");

if($this->form_validation->run() == FALSE){

  $this->login();

} else {

  $email_address = $this->input->post('email_address');
  $password = md5($this->input->post('password'));
  $prev_page = $this->input->post('referrer');

  $found_user = $this->account_model->validate_user($email_address, $password); // calls to function of the same name in the model, returns array.

  if($found_user){

    $session_data = array(
      'user_id' => $found_user->user_id,
      'is_logged_in' => TRUE
    );

    // Debug code

      if($this->session->set_userdata($session_data)){
        echo "success session";
        } else {
        echo "failure session";
      }

  } else {
    //Debug code
    echo 'no user found';
  }
}
}

型号:

  function validate_user($email_address, $password){

$this->db->where('email_address', $email_address);
$this->db->where('password', $password);
$query = $this->db->get('user');

if($query->num_rows() == 1){

   foreach($query->result() as $row){
        $data = $row;
      }
      return $data;

} else {
    return FALSE;
}

}

2 个答案:

答案 0 :(得分:1)

我将此作为另一个答案发布,因此我可以粘贴此代码段。我认为一切都正常。 set_userdata函数返回void,因此您无需将其封装在if语句中。

而不是以下代码:

if($this->session->set_userdata($session_data)){
    echo "success session";
    } else {
    echo "failure session";
  }

应该是:

this->session->set_userdata($session_data);

您可以使用此功能在会话中添加新数据或更改现有数据;如果已经存在数据并不重要。

另一个答案:

您是否正在加载会话库?作为一个常用的库,我建议将它加载到自动加载配置文件中,如下所示:

$autoload['libraries'] = array('session', 'other libraries etc');

答案 1 :(得分:0)

解决!!

好吧现在似乎正在运行,我认为问题可能是尝试设置已经设置的set_userdata!

虽然我不知道为什么如果我正在更新或添加那里的数据它会返回FALSE。 我确保所有会话数据都被销毁并删除条件,现在似乎有一个持续的会话。