Php 到Laravel 5的多个中间件路由不工作

Php 到Laravel 5的多个中间件路由不工作,php,laravel,authentication,laravel-5,laravel-middleware,Php,Laravel,Authentication,Laravel 5,Laravel Middleware,我想在以“管理员”和“珠宝商”身份登录时查看仪表板。 当我以“管理员”身份登录时,它会重定向到仪表板,当我以珠宝商身份登录时,它不会转到仪表板。 我有两种类型的管理和表格,即。。“管理员”、“珠宝商” 在auth.php中,我创建了两种类型的提供者 'guards' => [ 'web' => [ 'driver' => 'session', 'provider' => 'users', ],

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

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

'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.php中声明了一个称为“AdminAuthenticated”的中间件

class AdminAuthenticated
{
    public function handle($request, Closure $next, $guard = null)
    {
        if (Auth::guard($guard)->check()) {
            return $next($request);
        }
        return redirect()->route('admin.login');
    }
}
Route::group(['prefix' => 'admin','middleware'=>
  ['adminAuth:admin','adminAuth:jeweler']], function () {
});
在web.php中,我们有

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

您可以在
$middlewareGroups
数组中添加中间件组,例如
'admin'=>['adminAuth:admin','adminAuth:jeweler']
并将您的组中间件设置为
admin
您应该查看
\illumb\Auth\middleware\Authenticate
中间件,并比较您自己的
AdminAuthenticated
中间件,如果它们都执行相同的验证逻辑。@apokryfos。。我尝试了这个,但是结果是一样的,不能用Jeweleri登录如果你需要两个中间件中的一个通过,那么你应该将它们组合成一个
AuthWithAdminOrJewler
中间件。Laravel没有“或”中间件,所有这些都必须通过。@apokryfos。。谢谢workedi尝试了这个,但结果是一样的,不能用珠宝登录修改你的答案到。。。。。。if($guards){$guards=explode('-',$guards);foreach($guards as$guard){if(Auth::guard($guards)->check(){return$next($request);}}}}}}return redirect()->route('admin.login');根目录为,'middleware'=>['adminAuth:jeweler admin']如果用户未在所有提供的保护上进行身份验证,此中间件将失败。我认为问题在于OP希望用户至少在一个guard上进行身份验证。if($guards){$guards=explode('-',$guards);foreach($guards作为$guard){if(Auth::guard($guard)->check(){return$next($request);}}}}}return redirect()->route('admin.login');根目录为,'middleware'=>['adminAuth:jeweler admin'],这也可以使用,但如果用逗号分隔它们,则它们将作为单独的参数传递给中间件,而不是单个参数,并且将位于func_get_args()数组中
Route::group([ 
      'prefix' => 'admin',
      'middleware' => 'adminAuth:admin,jewler' 
    ], function () { ...