CakePHP 3:根据用户角色不同的登录重定向
我正在使用CakePHP3,并试图在用户登录后更改默认路由。我想根据用户的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' =>
角色\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());
}
}
}
}