5

我开始使用 CakePHP,但在设置 Auth 组件时遇到问题。每次用户注销时,cake 都会将他们重定向回登录。 您会看到我在注销()期间尝试删除/取消设置一些 cookie。这是因为我正在使用 Wordpress 站点设置单点登录,因此我希望用户从两个站点都注销。

我的应用控制器:

class AppController extends Controller {    

public $components = array(
    'Session',
    'Cookie',
    'Auth'      => array(
        'loginRedirect'     => array('controller' => 'questions', 'action' => 'index'), 
        'logoutRedirect'    => array('controller' => 'pages', 'action' => 'display', 'home')            
    )
);
public function beforeFilter() {
    $this->Auth->allow('index', 'view', 'login', 'logout', 'display');
}
}

用户控制器:

class UsersController extends AppController {

public function beforeFilter() {
    parent::beforeFilter();
    $this->Auth->allow('add', 'logout', 'login');
}

...

public function login() {
//who cares
}

public function logout() {

    $wp_cookie = grab_wp_cookie(); //this grabs a specific cookie
    $cookie_name = (isset($wp_cookie['name'])) ? $wp_cookie['name'] : NULL;
      //NONE OF THESE WORK...
    $this->Cookie->write($cookie_name, '', false, time()-3600);
    $this->Cookie->delete($cookie_name);
    $this->Cookie->destroy();

    $this->redirect($this->Auth->logout());
}
4

3 回答 3

1

您似乎无法在未登录的情况下访问该页面。(您可以尝试在不登录的情况下访问 URL 来检查它)

beforeFilter解决方案是在您的 PagesController中添加此功能:

public function beforeFilter(){
    parent::beforeFilter();

    $this->Auth->allow();
}
于 2013-04-04T08:50:16.827 回答
0

PagesController 将采用 AppController 的 beforeFilter。我可能会这样做:

/**
 * GET /users/logout
 */
public function logout() {
    $this->Auth->logout();
    $this->redirect(array('controller' => 'pages', 'action' => 'display', 'home'));
}

您不需要允许注销,因为注销没有视图。您的应用控制器 beforeFilter 应如下所示:

public function beforeFilter() {
    $this->Auth->allow('index', 'view', 'display');
}
于 2013-08-08T15:44:49.287 回答
0

尝试使用:

return $this->redirect($this->Auth->logout());

在中找到片段: 简单的身份验证和授权组件

并且不要忘记从 beforeFilter 中删除“Login”和“logOut”。

于 2013-09-12T11:04:40.483 回答