我试图在管理员用户没有分配的角色的用例中找到解决方案。
在仪表板视图中,它不会为用户呈现 url,而如果我直接访问仪表板/用户,我会得到:
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>
我已成功生成默认角色和权限
命令/GenerateRoles.php
public function handle()
{
$this->info('Generating default roles and permissions...');
$admin = User::create(
[
'name' => 'administrator',
'email' => '[email protected] /cdn-cgi/l/email-protection',
'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]);
}
它可能会出什么问题?谢谢你的时间。