如果用户在登录我的Codeigniter网络应用程序后直接点击浏览器的“后退”按钮,他们将被带回登录表单。相反,我希望将用户定向到主页。
此外,当用户退出时,我想阻止访问“帐户”页面,但我也不知道如何执行此操作。
有什么建议吗?
我已在下面附上我的登录模式。
控制器:
class Account extends CI_Controller{
public function __construct()
{
parent::__construct();
$this->load->model('masterentry_model');
$this->load->model('account_model');
// Your own constructor code
}
public function index()
{
if($this->session->userdata('logged_in') != TRUE){//checking loged in
$this->load->view('signin');
}else{
$data['location'] = $this->masterentry_model->getLocation();
$data['activeUser'] = $this->masterentry_model->userActive();
$data['flag'] = "home";
$this->load->view('home', $data);
//redirect('account');
}
}
//login process
public function loginsum(){
$this->load->library('form_validation');
$this->form_validation->set_rules('password', 'password', 'required|callback_check_exists');
if($this->form_validation->run() == true){
if($this->session->userdata('logged_in') == TRUE)
{
//$path = get_redirect_path();
redirect('account');
}
}
else{
if($this->session->userdata('logged_in') != TRUE)
{
$this->load->view('signin');
}
else
{
redirect('account');
}
}
}
//check email and password with database correct or not
public function check_exists($password){
$email = $this->input->post('email');
$result = $this->account_model->logincheck($email, $password);
if($result == 0)
{
$this->form_validation->set_message('check_exists', 'Email (or) Password incorrect');
return false;
}
else
{
return true;
}
}
//logout process
public function logout(){
$session_array = array(
'email' => "",
'user_id' => "",
'logged_in' => FALSE
);
$this->session->unset_userdata($session_array);
$this->index();
}
}
型号:
class Account_model extends CI_Model{
function __construct(){
parent::__construct();
}
public function logincheck($email, $password){
//echo "SELECT * FROM `account` WHERE email = '$email' AND password = '$password)'";
$query = $this->db->query("SELECT * FROM `account` WHERE email = '$email' AND password = '".md5($password)."'");
//checking row existes
if($query->num_rows() == 1){
$row = $query->row();
$session_array = array(
'email' => $row->email,//storing email in session
'user_id' => $row->id,//storing userid in session
'logged_in' => TRUE
);
$this->session->set_userdata($session_array);
return 1;
}else{
return 0;
}
}
}
答案 0 :(得分:1)
在constructor function
的{{1}}中添加这些标头,以防止缓存上一页
controller