1

我有一个由所有控制器继承的基类。我在基类中有一个函数,它使用 Auth 确定登录用户的角色。一旦确定了用户角色,就设置了变量 $LoggedIn_role。

此方法在初始页面加载时正确调用,但后来我发出 ajax 调用以检查用户是否仍然登录,当时 Auth::logged_in() 总是返回 0。

我使用的 kohana 版本是 3.3

任何人都可以建议规避此问题的最佳方法是什么。谢谢。

登录 -

if ($ValidObj->check()) {

                    if (Auth::instance()->login($_POST['email'], $_POST['password'],FALSE)) {
                        $this->DoPostLoginJobs();
                    } else {
                        $this->ManageError(Controller_Application::MsgWrongUserCredentials);
                    }
                } else {
                    $this->Form_Errors = $ValidObj->errors('');
                }

注销 -

public function action_logout() {

        $loggedout = Auth::instance()->logout();
        if ($loggedout)
           HTTP::redirect ('/home/'); // redirects to the home page.
    }

在 controller_Application 内部。所有控制器的基类

 public function DetermineUserRole() {
        $this->LoggedIn_Role = Controller_Application::None;
        try {

            if (Auth::instance()->logged_in('freelancer')) {
                $this->LoggedIn_Role = Controller_Application::Freelancer;
                $this->LoggedIn_Id = Auth::instance()->get_user()->pk();
            } else if (Auth::instance()->logged_in('employer')) {
                $this->LoggedIn_Role = Controller_Application::Employer;
                $this->LoggedIn_Id = Auth::instance()->get_user()->pk();
            }
        } catch (Gettrix_Exception $exc) {
            $this->ManageError(Controller_Application::RedirectNonRecoverableError);
        }



public function before() {
if ($this->request->is_ajax()) {

    $this->auto_render = false;

}


 $this->DetermineUserRole();

if($this->auto_render==TRUE){
parent::before();

   $this->template->content = '';
    $this->template->styles = array();
    $this->template->scripts = array();

View::set_global('site_name', 'TheWebTeam');
View::bind_global('Form_Errors', $this->Form_Errors);
View::bind_global('LoggedIn_Role', $this->LoggedIn_Role);
 View::bind_global('LoggedIn_Id', $this->LoggedIn_Id);
View::bind_global('InvitedEmail', $this->InvitedEmail);
View::bind_global('InvitedUniqueID', $this->InvitedUniqueID);
  View::bind_global('scripts', $this->template->scripts); 
   View::bind_global('styles', $this->template->styles);
}

//这是在主页控制器内部,它列出了登录用户的所有作业。

     public function action_joblist()
   {
     echo  Auth::instance()->logged_in() . //The state holds to the initial state, doesn't //change when the user is logged out or logged in.
    }

请注意,action_joblist() 是通过 AJAX/Jquery 调用来调用的。

4

1 回答 1

0

按照链接中给出的说明解决了这个问题:http: //forum.kohanaframework.org/discussion/9619/session-timeout-corruption-problems/p1

于 2014-08-30T12:27:59.307 回答