PHP - 后台权限
生活随笔
收集整理的這篇文章主要介紹了
PHP - 后台权限
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
PHP 后臺權限 分為
權限,角色,和用戶
角色有不同的權限,用戶有不同的角色,當然你也可以讓用戶只有一個角色。
所以我們要建四個表 public function up(){//角色表Schema::create('admin_roles', function (Blueprint $table) {$table->increments('id');$table->string('name',30)->default('');$table->string('description',100)->default('');$table->timestamps();});//權限表Schema::create('admin_permissions', function (Blueprint $table) {$table->increments('id');$table->string('name',30)->default('');$table->string('description',100)->default('');$table->timestamps();});//角色權限表Schema::create('admin_permission_roles', function (Blueprint $table) {$table->increments('id');$table->integer('role_id');$table->integer('permission_id');$table->timestamps();});//用戶角色表Schema::create('admin_role_user', function (Blueprint $table) {$table->increments('id');$table->integer('role_id');$table->integer('user_id');});}
然后進行模型關聯
1.權限與角色 之間的多對多關聯
2.角色與用戶 之間的關聯
/** 一個用戶有哪些角色*/public function roles(){return $this->belongsToMany(\App\AdminRole::class, 'admin_role_user', 'user_id', 'role_id')->withPivot(['user_id', 'role_id']);}3 使用Gate來進行權限控制,在路由 和 前臺 一起進行權限控制。
$permissions = \App\AdminPermission::with('roles')->get();foreach ($permissions as $permission) {Gate::define($permission->name, function($user) use($permission) {return $user->hasPermission($permission);});}//路由Route::group(['middleware'=>'can:system'], function (){});//前臺@can('post')@endcan總結
以上是生活随笔為你收集整理的PHP - 后台权限的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 商务与经济统计++原书第12版+[(美)
- 下一篇: EBS业务学习之应收管理