codeigniter sessions_destroy () не работает должным образом, что я делаю не так?

Я новичок в codeigniter. Я использую форму входа в систему как администратор. Когда администратор входит в систему с правильным именем пользователя и паролем, он / она направляется на домашнюю страницу с переменной сеанса. А затем, если он нажимает кнопку выхода, сеанс должен быть разрушен и перенаправляет пользователя на страницу входа т.е. авторизуйтесь на странице формы.

Первый контроллер - admin:

<?php
class Admin extends CI_Controller
{
    function index()
    {
        $data['main_content'] = 'admin/log_in';
        $this -> load -> view('includes/admin/admin_template', $data);
    }
    function log_in()
    {
        $this->load->model('admin_model');
        $query = $this -> admin_model -> validate();
        if ($query)// if the user's credentials validated...
        {
            $data = array('user_name' => $this -> input -> post('user_name'), 'is_logged_in' => true);
            $this -> session -> set_userdata($data);
            redirect('admin/home/admin_home');
        } else// incorrect username or password
        {
            $this -> index();
        }
    }
    function log_out()
    {
        $this->session->sess_destroy();
        redirect('/admin/admin','refresh');
    }
}

Второй контроллер - домашний контроллер:

<?php
class Home extends CI_Controller
{
    function __construct()
    {
        parent:: __construct();
        $this->is_logged_in();
    }
    function is_logged_in() 
    {
        $is_logged_in = $this -> session -> userdata('is_logged_in');
        if (!isset($is_logged_in) || $is_logged_in != true)
        {
            $this -> load -> view('admin/forbidden');
        }
    }
    function admin_home()
    {
        $data['main_content'] = 'home_view';
        $this->load->view('admin/home_view');
    }
}

Модель - admin_model:

<?php
class Admin_model extends CI_Model
{
    function __construct()
    {
        parent:: __construct();
    }
    function validate()
    {
            $this->db->where('user_name',$this->input->post('user_name'));
            $this->db->where('password', $this->input->post('password'));
            $query = $this->db->get('user');
            if($query->num_rows==1)
            {
                return true;
            }
    }
}

Теперь предполагается, что пользователь выйдет из системы и уничтожит сеанс, но если я нажму кнопку «Назад» кнопку моего браузера, я могу вернуть страницу, которой не должно было быть, и сеанс не будет разрушен. скажите, пожалуйста, что я здесь делаю не так. Я использую codeigniter 2.1.0.

8
задан Jav_Rock 27 January 2012 в 08:31
поделиться