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);
}
我有一个角色中间件。 当我从我的控制器传递角色作为一个字符串时它正常工作,但当作为一个数组传递时,它不起作用。 这样中间件就能正常工作。
但是当我这样改变时,它不起作用。 p>
下面, 是我的中间件。 p>
$ this-> middleware('HasRole:User | Admin | Author') - >除了(['userEdit','roleEdit','permissionEdit','userUpdate'] ); code> p>
$ this-> middleware(' HasRole:用户,管理员,作者 ') - >除了([' USEREDIT”, 'roleEdit', 'permissionEdit', 'userUpdate']); 代码> 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);
}