是什么原因导致会话重新创建或在页面刷新后消失?

时间:2013-08-18 12:32:25

标签: php codeigniter session

我在我的项目中使用codeigniter,我有一个登录模块,我对每个模块进行身份验证。当会话不存在时,重定向到登录页面。所以,这有效,但有时可能会发生,当我登录然后刷新页面时,我被重定向到登录页面(意味着会话已经消失)。

请不要试图告诉我使用其他库,例如php native等。我只是想知道造成这个问题的原因是什么。

function _admin_login()
{
    $this->form_validation->set_rules($this->login_rules);

    $data['title'] = "Login";
    $data['form_url'] = $this->uri->uri_string();   
    $data['login_btn'] = form_submit('login','Sign In','class="btn btn-large btn-block btn-primary"');


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

            $data['user'] = form_input('username','','class="input-block-level input-large" placeholder="Username"');
            $data['passw'] = form_password('password','','class="input-block-level input-large" placeholder="Password"');

            $this->template->set('title','Login');
            $this->template->load('template_login','login_view',$data);

        }else{
            $username = $this->input->post('username',true);
            $row = $this->authentication_model->get_user_info($username);

            $this->session->set_userdata('user',$row['user_id']);
            $this->session->set_userdata('username',$row['username']);
            $this->session->set_userdata('login_state',true);
            $this->authentication_model->update_last_login();


                redirect('product');    
        }

}

这是我的登录脚本,如果验证通过,那么会话已设置...并且在每个控制器中我都检查了会话脚本。示例如下:

$this->authentication_plugin->check_logged_in();

function check_logged_in()
    {
        if(logged_in() === FALSE){
            set_alert('Login in to view this page!!','error');
            set_bookmark('login_url');
            redirect("login");
        }
    }

function logged_in()
{
    $CI =& get_instance();
    $user = $CI->session->userdata('user');

    if(!$CI->load->library('session')){
            echo "no session is loaded";
            die;
    }

    if(!empty($user)){      
        return true;
    }else{  
        return false;
    }
}

有什么想法吗?谢谢!

1 个答案:

答案 0 :(得分:1)

  • 自动加载会话库并从登录脚本中删除它。 在config / autoload.php中寻找$ autoload [' libraries'] 添加'会话'

  • config / config.php中的
  • 向下滚动到cookie配置并查找$ config [' sess_cookie_name'] 确保cookie名称中没有下划线。您必须更改codeigniter默认名称才能执行此操作。

  • 通过在构造函数中进行会话检查来进行测试。快速检查会议是否有效。