CakePHP 3:根据用户角色不同的登录重定向

CakePHP 3:根据用户角色不同的登录重定向,php,cakephp,cakephp-3.x,Php,Cakephp,Cakephp 3.x,我正在使用CakePHP3,并试图在用户登录后更改默认路由。我想根据用户的角色\u id设置不同的默认路由 我找到了一个,但它只适用于CakePHP 2。 我不能在CakePHP3中使用它,我不能在引导中使用会话组件 所以我在AppController中尝试了这个 public $redirects = [ 'admin' => ['controller' => 'Clients', 'action' => 'statistics'], 'user' =>

我正在使用CakePHP3,并试图在用户登录后更改默认路由。我想根据用户的
角色\u id
设置不同的默认路由

我找到了一个,但它只适用于CakePHP 2。 我不能在CakePHP3中使用它,我不能在引导中使用会话组件

所以我在AppController中尝试了这个

public $redirects = [
    'admin' => ['controller' => 'Clients', 'action' => 'statistics'],
    'user' => ['controller' => 'Clients', 'action' => 'index'],
];
public function initialize()
{
    parent::initialize();
    ...
    if ($this->Auth->user()) 
        Configure::write('Route.default', $this->redirects[$this->Auth->user('role_id')]);
    else
        Configure::write('Route.default', ['controller' => 'Users', 'action' => 'login']);
    Router::scope('/', function($routes) {
        $routes->connect('/', Configure::read('Route.default'));
        $routes->fallbacks('InflectedRoute');
    });
}
我的默认路线是

$routes->connect('/', \Cake\Core\Configure::read('Route.default'));
我在bootstrap.php中将
Route.default
定义为

Configure::write('Route.default', ['controller' => 'Users', 'action' => 'login']);
但是当我打开
/
页面时,我仍然会看到
用户/登录
页面,即使我已经登录了

因此,我在
Router::scope

if (
    $this->Auth->user() 
    && $this->request->params['controller'] == 'Users' 
    && $this->request->params['action'] == 'login'
) {
    $this->redirect(Configure::read('Route.default'));
}

有人能帮我吗?

嘿,我找到了解决办法

在App\Routing\Filter中创建一个文件,如下所示:

  <?php
namespace App\Routing\Filter;

use Cake\Event\Event;
use Cake\Routing\DispatcherFilter;

class HFilter extends DispatcherFilter {

    public function beforeDispatch(Event $event) {
        $request = $event->data['request'];
        if (isset($request->url) && $request->url == '') {
            if ($request->session()->read('Auth.User')){
                $request->params['controller'] = 'Users';
                $request->params['action'] = 'index';
            } else { 
                $request->params['controller'] = 'Pages';
                $request->params['action'] = 'home';
            } 
        }
    }
}
?>

我们可以从会话数据中检查用户角色,并根据角色进行重定向

我们可以在用户控制器登录功能中进行如下编辑

public function login()
{


    if ($this->request->is('post')) {
        $user = $this->Auth->identify();
        if ($user) {
            $this->Auth->setUser($user);


            $loggedUser = $this->request->session()->read('Auth.User');
            if($loggedUser['role'] == 'customer'){
                return $this->redirect('/');
            }else if($loggedUser['role'] == 'admin'){
                return $this->redirect('/admin');
            }else{
                return $this->redirect($this->Auth->redirectUrl());
            }


        }

    }
}

我的cakephp版本是3.3.8

你为什么要这么做?当一个未登录的用户访问一个受保护的操作时,重定向会自动发生(假设auth组件是这样配置的),而对于登录的用户则不会,所以这听起来正是您试图在这里执行的操作?@ndm,谢谢您的回答,但我想为不同的角色设置不同的“根”页面,当角色id为'admin'的用户打开我的网站如“example.com”时,他会看到“clients/statistics”,当角色id为'user'的用户打开网站时,他会看到“clients/index”。不同角色的不同主页。我明白了,你可能想把它添加到你的问题中,因为这是一个相关的因素。我更改了代码,现在它工作得非常完美<代码>$request->params['action']='display'
$request->params['pass'][0]='home'注意:我想在不同角色访问“/”路线时,为他们提供不同的页面。这只会使他们在登录后重定向到页面。
public function login()
{


    if ($this->request->is('post')) {
        $user = $this->Auth->identify();
        if ($user) {
            $this->Auth->setUser($user);


            $loggedUser = $this->request->session()->read('Auth.User');
            if($loggedUser['role'] == 'customer'){
                return $this->redirect('/');
            }else if($loggedUser['role'] == 'admin'){
                return $this->redirect('/admin');
            }else{
                return $this->redirect($this->Auth->redirectUrl());
            }


        }

    }
}