Codeigniter实现处理用户登录验证后的URL跳转
Codeigniter处理用户登录验证后URL跳转,主要涉及到了My_Controller.php页面以及登录验证模块User.php页面,具体代码如下:
My_Controller.php页面:
class MY_Controller extends CI_Controller
{
public function __construct()
{
parent::__construct();
/*判断是否登录,判断当前URL是否是auth/login*/
if ( ! $this->tank_auth->is_logged_in()
&& ( $this->router->fetch_class() != 'auth' && $this->router->fetch_method() != 'login'))
{
$redirect = $this->uri->uri_string();
if ( $_SERVER['QUERY_STRING'])
{
$redirect .= '?' . $_SERVER['QUERY_STRING'];
}
/*跳转到用户登陆页面,指定Login后跳转的URL*/
redirect('auth/login?redirect='.$redirect);
}
}
}
User.php页面:
class User extends MY_Controller
{
function login()
{
if ($this->tank_auth->is_logged_in()) { // logged in
redirect('/');
} else {
//other codes here......
/*判断是否有redirect信息*/
$data['redirect'] = isset($_GET['redirect']) ? $_GET['redirect'] : '/';
if ($this->form_validation->run()) { // validation ok
if ($this->tank_auth->login(
$this->form_validation->set_value('login'),
$this->form_validation->set_value('password'),
$this->form_validation->set_value('remember'),
$data['login_by_username'],
$data['login_by_email'])) { // success
redirect($data['redirect']);
} else {
//error handling
}
}
$this->load->view("login_form")
}
}
/*
Note: 在login_form中需要注意,提交表单的form地址:
<?php echo form_open(site_url("/auth/login?redirect=".$redirect)); ?>
*/
}
在login_form中需要注意,提交表单的form地址为:
<?php echo form_open(site_url("/auth/login?redirect=".$redirect)); ?>