Laravel Middleware无法正常运行角色中间件

Laravel Middleware无法正常运行角色中间件

问题描述:

I have a role middleware. when i pass to role from my controller as a string it's work properly but when pass as an array it's not working. This way middleware work properly. $this->middleware('HasRole:User|Admin|Author')->except(['userEdit','roleEdit','permissionEdit','userUpdate']);

But when I change like this, it's not working.

$this->middleware('HasRole:User,Admin,Author')->except(['userEdit','roleEdit','permissionEdit','userUpdate']);

Here, is my middleware.

public function handle($request, Closure $next, ...$role)
{

    $roles=is_array($role)? $role: explode('|', $role);
    //dd($roles);

    if($request->user()===null)
    {
        return response('Insufficient Access',401);
    }

    if($request->user()->hasAnyRole($roles) || !$roles)
    {
         return $next($request);
    }
      return response('Insufficient Permission',401);
    //return $next($request);
}

我有一个角色中间件。 当我从我的控制器传递角色作为一个字符串时它正常工作,但当作为一个数组传递时,它不起作用。 这样中间件就能正常工作。 $ this-> middleware('HasRole:User | Admin | Author') - >除了(['userEdit','roleEdit','permissionEdit','userUpdate'] ); code> p>

但是当我这样改变时,它不起作用。 p>

$ this-> middleware(' HasRole:用户,管理员,作者 ') - >除了([' USEREDIT”, 'roleEdit', 'permissionEdit', 'userUpdate']); 代码> p>

下面, 是我的中间件。 p>

 公共函数句柄($ request,Closure $ next,... $ role)
 {
 
 $ roles = is_array($ role)  ?  $ role:explode('|',$ role); 
 // dd($ roles); 
 
 if if($ request-> user()=== null)
 {
}返回响应(  “访问不足”,401); 
} 
 
 if($ request-> user() - > hasAnyRole($ roles)||!$ roles)
 {
 return $ next($ request)  ); 
} 
返回响应('Insufficient Permission',401); 
 //返回$ next($ request); 
} 
  code>  pre> 
  div>

controller

public function __construct()
{
    $this->middleware('HasRole:User,Admin,Author')->except(['userEdit','roleEdit','permissionEdit','userUpdate']);
}

your middleware

read here http://php.net/manual/en/functions.arguments.php#functions.variable-arg-list about the ...$

public function handle($request, Closure $next, ...$roles)
{
    // $roles is array('User', 'Admin', 'Author')
    // 0 => 'User',
    // 1 => 'Admin',
    // 2 => 'Author'

    if($request->user()===null)
    {
        return response('Insufficient Access',401);
    }

    if($request->user()->hasAnyRole($roles) || !$roles)
    {
         return $next($request);
    }
      return response('Insufficient Permission',401);
    //return $next($request);
}