CakePHP 3.2:防止在用户未登录时显示authError

时间:2016-06-26 10:56:25

标签: authentication cakephp authorization cakephp-3.0

即使用户未登录并尝试打开主页,在重定向到登录页面后,也会显示authError。是否有一种优雅的方法可以防止这种情况,而无需修改Auth组件?这是我加载Auth组件的方式(我使用TinyAuth作为授权适配器):

$this->loadComponent('Auth', [
                'loginAction' => [
                    'controller' => 'Users',
                    'action' => 'login'
                ],
                'loginRedirect' => [
                   'controller' => 'Home',
                   'action' => 'index'
                ],
                'authError' => 'You dont have permissions for that action',
                'authenticate' => [
                    'Form' => [
                        'fields' => [
                            'username' => 'email',
                            'password' => 'password'
                        ],
                        'scope' => ['Users.active' => true],
                        'contain' => ['Roles']
                    ]
                ],
                'authorize' => [
                    'TinyAuth.Tiny' => [
                        'roleColumn' => 'role_id',
                        'rolesTable' => 'Roles',
                        'multiRole' => true,
                        'pivotTable' => 'roles_users',
                        'superAdminRole' => null,
                        'authorizeByPrefix' => false,
                        'prefixes' => [],
                        'allowUser' => false,
                        'adminPrefix' => null,
                        'autoClearCache' => true
                    ] 
                ]
            ]
        );

1 个答案:

答案 0 :(得分:6)

根据CakePHP's documentation,您可以通过将authError设置为false来阻止显示错误消息。

  

有时,您希望仅在显示授权错误后显示   用户已登录。您可以通过设置来抑制此消息   它的值为布尔值假。

这应该禁用错误消息:

if (!$this->Auth->user()) {
    $this->Auth->config('authError', false);
}