导致会话在页面刷新后被重新创建或消失的原因


What causes the session to be recreated or to be gone after a page refresh?

我在项目中使用codeigniter,我有一个登录模块,我对每个模块进行身份验证。如果会话不存在,则重定向到登录页面。因此,这是有效的,但有时当我登录并刷新页面时可能会发生这种情况,我会被重定向到登录页面(意味着会话已经结束)。

请不要试图告诉我使用另一个库,如php原生等。我只想知道是什么问题导致了这一点。

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;
    }
}

有什么想法吗?谢谢

  • 自动加载会话库并将其从登录脚本中删除。在config/autoload.php中查找$autoload['librarys']添加"会话"

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

  • 通过在构造函数中执行会话检查进行测试。这是一个快速的健全性检查,看看会话是否正常工作。