问题描述
使用播种机为角色分配权限时,在权限表中,它会将guard_name 设为“web”, 但是当通过 CRUD 添加权限时,它会将guard_name 作为“sanctum”。 在将此新权限分配给 Role 时,它会出错。
RoleTableSeeder.PHP:
public function run()
{
DB::table('roles')->delete();
$roles_json = File::get("database/seeders/data/roles.json");
$perms_json = File::get("database/seeders/data/permissions.json");
$roles_data = json_decode($roles_json);
$perms_data = json_decode($perms_json);
Log::info("Starting Roles Population...");
foreach ($roles_data->roles as $role) {
$rl = Role::create([
'name' => $role->name,'role_desc' => $role->role_desc
]);
$rol = Role::findOrFail($rl['id']);
foreach ($perms_data->permissions as $perm) {
$per = Permission::findOrFail($perm->id);
$rol->givePermissionTo($per);
}
Log::info("Populating... " . $role->name );
}
Log::info("Roles Populated Successfully.");
}
角色控制器:
//---Assign Permission to Role
public function PermissionToRole($request,$id) {
$selectedRole = Role::find($id);
$selectedRolePermissions = $selectedRole->getAllPermissions();
$users = User::role($id)->get();
//---Remove Selected Role To Permissions
for ($i=0; $i < count($selectedRolePermissions); $i++) {
$selectedRole->revokePermissionTo($selectedRolePermissions[$i]);
}
if ($request->input('option') != null)
{
for ($k=0; $k < count($request->input('option')); $k++)
{
//---Insert New Permission To Role
$findPermission = Permission::find($request->input('option')[$k]);
$selectedRole->givePermissionTo($findPermission);
//---Remove Old Permissions From User & Assign New Permissions To Users
for ($m = 0 ; $m < count($users) ; $m++) {
for ($j = 0 ; $j < count($users[$m]->getDirectPermissions()) ; $j++) {
if ($findPermission->id == $users[$m]->getDirectPermissions()[$j]->id) {
$users[$m]->revokePermissionTo($users[$m]->getDirectPermissions()[$j]);
}
}
}
}
return back()->with('success','');
}
}//---End of Function PermissionToRole
如何将两个 guard_name 都设为“web”而不是“sanctum”,因为在将此权限分配给 Role 时,我收到一个错误:
路由/web.PHP
Route::get('pertorole/{role_id}','Roles\RoleController@PerToRoleEdit')->name('role.pertoroleedit')->middleware('can:Assign Permission');
Route::patch('pertorole/{role_id}','Roles\RoleController@PerToRoleUpdate')->name('role.pertoroleupdate')->middleware('can:Assign Permission');
app/Http/Kernel.PHP
<?PHP
namespace App\Http;
use Illuminate\Foundation\Http\Kernel as HttpKernel;
class Kernel extends HttpKernel
{
/**
* The application's global HTTP middleware stack.
*
* These middleware are run during every request to your application.
*
* @var array
*/
protected $middleware = [
\App\Http\Middleware\TrustProxies::class,\Fruitcake\Cors\HandleCors::class,\App\Http\Middleware\PreventRequestsDuringMaintenance::class,\Illuminate\Foundation\Http\Middleware\ValidatePostSize::class,\App\Http\Middleware\Trimstrings::class,\Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class,];
/**
* The application's route middleware groups.
*
* @var array
*/
protected $middlewareGroups = [
'web' => [
\App\Http\Middleware\EncryptCookies::class,\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,\Illuminate\Session\Middleware\StartSession::class,\Laravel\Jetstream\Http\Middleware\AuthenticateSession::class,\Illuminate\View\Middleware\ShareErrorsFromSession::class,\App\Http\Middleware\VerifyCsrftoken::class,\Illuminate\Routing\Middleware\SubstituteBindings::class,\App\Http\Middleware\Localization::class,],'api' => [
'throttle:api',];
/**
* The application's route middleware.
*
* These middleware may be assigned to groups or used individually.
*
* @var array
*/
protected $routeMiddleware = [
'auth' => \App\Http\Middleware\Authenticate::class,'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,'role' => \Spatie\Permission\Middlewares\RoleMiddleware::class,'permission' => \Spatie\Permission\Middlewares\PermissionMiddleware::class,'role_or_permission' => \Spatie\Permission\Middlewares\RoleOrPermissionMiddleware::class,];
}
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)