我试图在管理员用户没有指定角色的用例中找到解决方案。 在仪表板视图中,它不会为用户呈现网址,而如果我直接访问信息中心/用户,我会得到:
Spatie \ Permission \ Exceptions \ UnauthorizedException
user does not have the right roles
应用程序/ HTTP / Kernel.php
protected $routeMiddleware = [
....
'role' => \Spatie\Permission\Middlewares\RoleMiddleware::class,
'permission' => \Spatie\Permission\Middlewares\PermissionMiddleware::class,
];
路由/ web.php
Route::group(
['middleware' => ['role:admin']],
function () {
Route::get('/dashboard/users', 'UsersController@index');
Route::get('/dashboard/users/{id}', 'UsersController@edit');
Route::patch('/dashboard/users/{id}', 'UsersController@update');
}
);
查看/ dashboard.blade.php
<div class="panel-body">
@hasrole('admin')
<li><a href="/dashboard/users">Manage Users</a></li>
@endhasrole
</div>
我已成功生成默认角色&amp;允许
命令/ GenerateRoles.php
public function handle()
{
$this->info('Generating default roles and permissions...');
$admin = User::create(
[
'name' => 'administrator',
'email' => 'adm@mail.com',
'password' => bcrypt('12345'),
]
);
// Create roles.
$adminRole = Role::create(['name' => 'admin']);
$supportRole = Role::create(['name' => 'support']);
$admin->assignRole('admin');
// Create permissions.
$userManagement = Permission::create(['name' => 'users management']);
$deleteImages = Permission::create(['name' => 'delete images']);
$datasetStatus = Permission::create(
['name' => 'change dataset building status']
);
$adminRole->givePermissionTo($userManagement);
$deleteImages->syncRoles([$adminRole, $supportRole]);
$datasetStatus->syncRoles([$adminRole, $supportRole]);
}
可能出错的是什么?谢谢你的时间。
答案 0 :(得分:3)
您应该覆盖渲染方法以重定向(或者您想要做的任何事情)。转到Expections / Handler.php并覆盖渲染函数,如下所示:
public function render($request, Exception $exception)
{
if ($exception instanceof \Spatie\Permission\Exceptions\UnauthorizedException) {
return redirect('/');
}
return parent::render($request, $exception);
}
源:https://github.com/spatie/laravel-permission#catching-role-and-permission-failures