0

我想知道是否有办法重定向到 Tank_auth 中的特定页面(如 adminpanel_view)。我查看了 Auth.php 控制器,但无法弄清楚如何重定向,如果它甚至可能的话..

我试过这个:

(Auth.php)

public function login() //login functie
{
    $this->breadcrumbs->page = array('link'=> base_url().'auth/login' ,'title' => 'Login');         
    $data['breadcrumbs'] = $this->breadcrumbs->get();
    if ($this->tank_auth->is_logged_in()) {                                 // logged in
        redirect('members/cpanel');
    } elseif ($this->tank_auth->is_logged_in(FALSE)) {                      // logged in, not activated
        redirect('/auth/send_again/');

    } else {
        $data['login_by_username'] = ($this->config->item('login_by_username', 'tank_auth') AND
                $this->config->item('use_username', 'tank_auth'));
        $data['login_by_email'] = $this->config->item('login_by_email', 'tank_auth');

        $this->form_validation->set_rules('login', 'Login', 'trim|required|xss_clean');
        $this->form_validation->set_rules('password', 'Password', 'trim|required|xss_clean');
        $this->form_validation->set_rules('remember', 'Remember me', 'integer');

        // Get login for counting attempts to login
        if ($this->config->item('login_count_attempts', 'tank_auth') AND
                ($login = $this->input->post('login'))) {
            $login = $this->security->xss_clean($login);
        } else {
            $login = '';
        }

        $data['use_recaptcha'] = $this->config->item('use_recaptcha', 'tank_auth');
        if ($this->tank_auth->is_max_login_attempts_exceeded($login)) {
            if ($data['use_recaptcha'])
                $this->form_validation->set_rules('recaptcha_response_field', 'Confirmation Code', 'trim|xss_clean|required|callback__check_recaptcha');
            else
                $this->form_validation->set_rules('captcha', 'Confirmation Code', 'trim|xss_clean|required|callback__check_captcha');
        }
        $data['errors'] = array();

        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('');

            } else {
                $errors = $this->tank_auth->get_error_message();
                if (isset($errors['banned'])) {                             // banned user
                    $this->_show_message($this->lang->line('auth_message_banned').' '.$errors['banned']);

                } elseif (isset($errors['not_activated'])) {                // not activated user
                    redirect('/auth/send_again/');

                } else {                                                    // fail
                    foreach ($errors as $k => $v)   $data['errors'][$k] = $this->lang->line($v);
                }
            }
        }
        $data['show_captcha'] = FALSE;
        if ($this->tank_auth->is_max_login_attempts_exceeded($login)) {
            $data['show_captcha'] = TRUE;
            if ($data['use_recaptcha']) {
                $data['recaptcha_html'] = $this->_create_recaptcha();
            } else {
                $data['captcha_html'] = $this->_create_captcha();
            }
        }
        $this->load->view('views/header');
        $this->load->view('auth/login_form', $data);
        $this->load->view('views/footer');
    }
}
4

1 回答 1

1

确保在使用函数之前已加载base_urlurl_helpersite_urlredirect. 并且您的代码无法运行,因为您错过了一个大括号。它应该是

public function login() //login functie
{
    $this->load->helper('url');
    $this->breadcrumbs->page = array('link'=> site_url('auth/login') ,'title' => 'Login');         
    $data['breadcrumbs'] = $this->breadcrumbs->get();
    if ($this->tank_auth->is_logged_in()) {      // logged in
        redirect('members/cpanel');
    }
}
于 2013-08-21T07:13:36.013 回答