无法在codeigniter中销毁会话 [英] unable destroy session in codeigniter

查看:86
本文介绍了无法在codeigniter中销毁会话的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我要实现的是一个简单的登录页面,如果用户成功登录,则重定向到主页,否则保留登录页面.

What I want to implement is a simple login page, if user login successfully, then redirect to main page, else remain login page.

我有1个名为login,的控制器和1个名为main的模型. 当用户单击登录按钮时,将调用login/login_send.

I have 1 controller named login, and 1 model named main. When user click the login button, the login/login_send will be called.

<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');

class Login extends CI_Controller{

function __construct() {
    parent::__construct();
    $this->load->model('model_login');
}

function index()
{
    if ($this->model_login->is_logged_in())
    {
        redirect('main');
    }
    else
    {
        // load login page
        $data['main'] = 'view_login';
        $data['style'] = 'style_login';
        $this->load->view('template', $data);           
    }
}

function login_send()
{
    $this->form_validation->set_rules('username', 'Username', 'trim|required');
    $this->form_validation->set_rules('password', 'Password', 'trim|required'); 

    if ($this->form_validation->run() == FALSE) 
    {
        $this->index();
    } 
    else 
    {
        if ( $this->model_login->validate_user() )
        {
            $user_session_data = array(
                'username' => $this->input->post('username'),
                'is_logged_in' => 1
            );
            $this->session->set_userdata($user_session_data);       
            redirect('main');
        }
        else 
        {
            redirect('login');
        }
    }       
}// end function login_send

function logout() 
{
    if ($this->model_login->is_logged_in())
    {
        $this->session->sess_destroy();
        $this->session->set_userdata(array('username' => '', 'is_logged_in' => 0));
        log_message('debug', 'Some variable was correctly set');
    }
    redirect('login','refresh');
}

}// end class Login
?>

Model_login此处只是通过检查会话数据来帮助验证用户是否已登录.

Model_login here is just to help to verify if user is logged in, by check the session data.

<?php
class Model_login extends CI_MOdel{

function _isUserExist($username, $password) 
{   
    $options = array(
        'UserName' => $username,
        'Password' => $password
    );
    $query = $this->db->get_where('userinfo', $options);
    return $query->num_rows() > 0;
}

function validate_user() 
{
    $username = $this->input->post('username');
    $password = $this->input->post('password');

    return ($this->_isUserExist($username, $password));
}

function is_logged_in() 
{
    $is_logged_in = $this->session->userdata('is_logged_in');

    if ( !isset($is_logged_in) || $is_logged_in != 1 ) return FALSE;
    else return TRUE;
}
}// end class model_login
?>

第一次登录,然后注销时,没有问题.但是,如果我第二次登录,则无法注销.即使登录/注销被正确调用,我也刷新了页面,但是session['is_logged_in'] == 1.我的代码有问题吗?

When first time login, and then logout, there is no problem. However, if I login second time, I can not log out. Even the login/logout was called correctly, I also refreshed the page, but the session['is_logged_in'] == 1. Something wrong with my code?

推荐答案

在您的application/config/config.php中尝试更改

$config['sess_time_to_update']  = 300; //This is the default setting in ver 2.1.1

$config['sess_time_to_update']  = 0;

几年前,这给我带来了一些问题

This gave me some problems a few years back

这篇关于无法在codeigniter中销毁会话的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆