博客列表 >PHP - laravel 的 简单权限控制

PHP - laravel 的 简单权限控制

晴天
晴天原创
2020年06月11日 19:41:58942浏览
  • 在中间件中执行权限控制
    ```php
    public function handle($request, Closure $next)
    {
    1. $admin = Auth::user(); // 取出该用户的session
    2. $gid = $admin->gid; // 取出 gid 权限id
    3. $rights = DB::table('admin_group')->where('gid',$gid)->item()['rights'];
    4. // 利用gid去数据库取出该角色的可用权限 [1,2,3,54,6,89,5,25].. 对应着菜单的mid
    5. if($rights){
    6. $rights = json_decode($rights); //转成数组
    7. }
  1. // 拿到当前用户访问菜单的控制器与方法
  2. $res = $request->route()->action['controller'];
  3. $res = explode('\\',$res);
  4. $route = array_pop($res);
  5. $route = explode('@',$route); // 返回数组 0=> 控制器 1=> 方法
  6. // 去数据库查到该方法的mid 然后判断mid 是否存在于可用权限$rights中
  7. $mid = DB::table('admin_menu')->where('controller',$route[0])->where('action',$route[1])->item()['mid'];
  8. // 如果不存在 返回权限不足
  9. if (!in_array($mid,$rights)) {
  10. return response('权限不足',200);
  11. }
  12. // 存在 继续执行
  13. return $next($request);
  14. }

```

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议