Laravel 5 路由的多个中间件不起作用

multiple middleware to Laravel 5 route not working

我想在以 "admin" 和 "jeweller" 身份登录时查看仪表板。 当我登录 "admin" 时,它会重定向到仪表板,当我以珠宝商身份登录时,它不会转到仪表板。 我有 2 种类型的管理员和表格,即.. "admin"、"jeweller"

在 auth.php 中,我创建了 2 种类型的提供者

'guards' => [
        'web' => [
            'driver' => 'session',
            'provider' => 'users',
        ],
        'admin' => [
            'driver' => 'session',
            'provider' => 'admins',
        ],
        'jeweler' => [
            'driver' => 'session',
            'provider' => 'jewelers',
        ],
    ],
 'providers' => [
        'users' => [
            'driver' => 'eloquent',
            'model' => App\User::class,
        ],
        'admins' => [
            'driver' => 'eloquent',
            'model' => App\Admin::class,
        ],
        'jewelers' => [
            'driver' => 'eloquent',
            'model' => App\Jeweler::class,
        ],
    ],

我已经声明了一个名为 "AdminAuthenticated" 的中间件,在 AdminAuthenticated.php 中我们有

class AdminAuthenticated
{
    public function handle($request, Closure $next, $guard = null)
    {
        if (Auth::guard($guard)->check()) {
            return $next($request);
        }
        return redirect()->route('admin.login');
    }
}

在web.php中我们有

Route::group(['prefix' => 'admin','middleware'=>
  ['adminAuth:admin','adminAuth:jeweler']], function () {
});

在内核中我们有

protected $middlewareGroups = [
        'web' => [
            \App\Http\Middleware\EncryptCookies::class,
            \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
            \Illuminate\Session\Middleware\StartSession::class,
            // \Illuminate\Session\Middleware\AuthenticateSession::class,
            \Illuminate\View\Middleware\ShareErrorsFromSession::class,
            \App\Http\Middleware\VerifyCsrfToken::class,
            \Illuminate\Routing\Middleware\SubstituteBindings::class,
        ],

        'api' => [
            'throttle:60,1',
            'bindings',
        ],
    ];
    protected $routeMiddleware = [
        'auth' => \Illuminate\Auth\Middleware\Authenticate::class,
        'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
        'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
        'can' => \Illuminate\Auth\Middleware\Authorize::class,
        'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
        'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,

        'adminAuth' => \App\Http\Middleware\AdminAuthenticated::class,
    ];
class AdminAuthenticated
{
    public function handle($request, Closure $next, ...$guards)
    {
        if ($guards) {

            foreach ($guards as $guard) {
                if (!Auth::guard($guard)->check()) {
                    return redirect()->route('admin.login');
                }
            }

            return $next($request);
        }
        return redirect()->route('admin.login');
    }
}

使用

Route::group(['prefix' => 'admin','middleware'=>
  ['adminAuth:admin,jeweler']], function () {
});

您可以这样做来检查其中一名守卫:

class AdminAuthenticated
{
    public function handle($request, Closure $next, $guard = null)
    {
        if (func_num_args() == 2 && \Auth::check()) { //Default guard
             return $next($request);     
        }  
        for ($i = 2; $i < func_num_args();$i++) {
             if (Auth::guard(func_get_arg($i))->check()) {
                 return $next($request);
             }
        }
        return redirect()->route('admin.login');
    }
}

如果指定的守卫之一通过,或者如果没有参数时默认守卫通过,则此中间件将通过。

您可以像这样使用它:

Route::group([ 
      'prefix' => 'admin',
      'middleware' => 'adminAuth:admin,jewler' 
    ], function () { ...