权限控制

laravel-admin已经内置了RBAC权限控制模块,展开左侧边栏的Auth,下面有用户、权限、角色三项的管理面板,权限控制的使用如下:

  1. use Encore\Admin\Auth\Permission;
  2. class PostController extends Controller
  3. {
  4. public function create()
  5. {
  6. // 检查权限,有create-post权限的角色可以访问
  7. Permission::check('create-post');
  8. // 'editor', 'developer'两个角色可以访问
  9. Permission::allow(['editor', 'developer']);
  10. // 'editor', 'developer'两个角色禁止访问
  11. Permission::deny(['editor', 'developer']);
  12. }
  13. }

其它使用方法

获取当前用户对象

  1. Admin::user();

获取当前用户id

  1. Admin::user()->id;

获取用户角色

  1. Admin::user()->roles;

获取用户的权限

  1. Admin::user()->permissions;

用户是否某个角色

  1. Admin::user()->isRole('developer');

是否有某个权限

  1. Admin::user()->can('create-post');

是否没有某个权限

  1. Admin::user()->cannot('delete-post');

是否是超级管理员

  1. Admin::user()->isAdministrator();

是否是其中的角色

  1. Admin::user()->inRoles(['editor', 'developer']);

权限中间件

可以在路由配置上结合权限中间件来控制路由的权限

  1. // 允许administrator、editor两个角色访问group里面的路由
  2. Route::group([
  3. 'middleware' => 'admin.permission:allow,administrator,editor',
  4. ], function ($router) {
  5. $router->resource('users', UserController::class);
  6. ...
  7. });
  8. // 禁止developer、operator两个角色访问group里面的路由
  9. Route::group([
  10. 'middleware' => 'admin.permission:deny,developer,operator',
  11. ], function ($router) {
  12. $router->resource('users', UserController::class);
  13. ...
  14. });
  15. // 有edit-post、create-post、delete-post三个权限的用户可以访问group里面的路由
  16. Route::group([
  17. 'middleware' => 'admin.permission:check,edit-post,create-post,delete-post',
  18. ], function ($router) {
  19. $router->resource('posts', PostController::class);
  20. ...
  21. });

权限中间件和其它中间件使用方法一致。

使用实例

比如现在有一个场景,对文章发布模块做权限管理,以创建文章为例

首先创建一项权限,进入http://localhost:8000/admin/auth/permissions,权限标识(slug)填写create-post,权限名称填写创建文章,这样权限就创建好了。第二步可以把这个权限直接附加给个人或者角色,在用户编辑页面可以直接把上面创建好的权限附加给当前编辑用户,也可以在编辑角色页面附加给某个角色。第三步,在创建文章控制器里面添加控制代码:

  1. use Encore\Admin\Auth\Permission;
  2. class PostController extends Controller
  3. {
  4. public function create()
  5. {
  6. // 检查权限,有create-post权限的用户或者角色可以访问创建文章页面
  7. Permission::check('create-post');
  8. }
  9. }

这样就完成了一个页面的权限控制。