невозможно уничтожить сессию в codeigniter - PullRequest
4 голосов
/ 01 февраля 2012

Я хочу реализовать простую страницу входа, если пользователь успешно войдет в систему, затем перенаправить на главную страницу, иначе останется страницей входа.

У меня есть 1 контроллер с именем login, и 1 модель с именем main. Когда пользователь нажимает кнопку входа, вызывается login / login_send.

<?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 здесь только для того, чтобы проверить, вошел ли пользователь в систему, путем проверки данных сеанса.

<?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. Что-то не так с моим кодом?

1 Ответ

9 голосов
/ 18 июня 2012

В вашем 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;

Это доставило мне некоторые проблемы несколько лет назад

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...