我需要在检查用户是否以编辑身份登录后重定向到配置文件页面...
这是我的代码:
<?php namespace App'Http'Middleware;
use Illuminate'Support'Facades'Auth;
use Illuminate'Support'Facades'Redirect;
use Closure;
class AdminMiddleware {
/**
* Handle an incoming request.
*
* @param 'Illuminate'Http'Request $request
* @param 'Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
if (Auth::check()) {
if (Auth::user()->roles->toArray()[0]['role'] == 'editor'){
return redirect('/profile');
}
return $next($request);
}
else {
return $next($request);
}
}
}
这段代码的问题是当用户是编辑器时,我得到无限循环......
这是我的路线:
Route::group(['middleware' => 'auth'], function(){
Route::get('home', ['middleware' => 'admin', function()
{
return view('home');
}]);
Route::get('profile', array(
'as' => 'profile',
'uses' => 'UserController@getProfile'
));
});
有人知道问题是什么吗?
您在App'Http'Kernel
中在哪里注册了中间件?
它是在受保护的$middleware = []
还是protected $routeMiddleware = []
?
如果在$middleware
中注册,它将在每个请求上运行,从而导致无限循环,如果是这样,则仅使用$routeMiddleware
我发现这是一个更少的代码和更少的基于角色重定向用户的决定,把它放在你的AuthController中.php
protected function authenticated( $user)
{
if($user->user_group == '0') {
return redirect('/dashboard');
}
return redirect('my-account');
}
https://laracasts.com/discuss/channels/laravel/how-best-to-redirect-admins-from-users-after-login-authentication
转到 Kernel.php
。它在app'http
.尝试找到protected $routeMiddleware
在该数组中,您需要添加此
'admin' => 'App'Http'Middleware'AdminMiddleware::class
之后它应该可以正常工作。希望这对任何面临相同问题的人有所帮助。