中间件,检查后如何重定向 拉拉维尔 5.


Middleware, how to redirect after check Laravel 5

我需要在检查用户是否以编辑身份登录后重定向到配置文件页面...

这是我的代码:

<?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

之后它应该可以正常工作。希望这对任何面临相同问题的人有所帮助。