我使用CakePHP 3并尝试在用户登录后更改默认路由。我想将默认路由设置为不同,具体取决于用户role_id
。
我找到了solution,但它仅适用于CakePHP 2。 我无法在CakePHP 3中使用它,我无法在bootstrap中使用Session组件。
所以我在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']);
但是当我打开/
页面时,即使我已经登录,我仍然会看到users/login
页面
所以我在Router::scope
if (
$this->Auth->user()
&& $this->request->params['controller'] == 'Users'
&& $this->request->params['action'] == 'login'
) {
$this->redirect(Configure::read('Route.default'));
}
有人可以帮我吗?
答案 0 :(得分:5)
我们可以从会话数据中检查用户角色,并根据角色进行重定向。
我们可以在用户控制器中编辑登录功能,如下所示
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
答案 1 :(得分:3)
在App \ Routing \ Filter中创建一个文件:
new_vec <- unname(tapply(vec, c(0, cumsum(diff(vec) > 1)), function(y) {
paste(unique(range(y)), collapse = "-")
}))
将其添加到bootstrap.php文件中,而不像名称那样使用过滤器
<?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';
}
}
}
}
?>