AccessAuth.php 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <?php
  2. namespace App\Http\Middleware\Manager;
  3. use Closure;
  4. use Illuminate\Http\Request;
  5. use App\Models\Manager\AuthRule;
  6. use App\Models\Manager\Personnel\RolesAuthRule;
  7. // 访问权限验证
  8. class AccessAuth
  9. {
  10. // 无需验证的路径
  11. protected $except = [
  12. 'manager/collect/product/product_name_specs_list',
  13. 'manager/process/sub_notice',
  14. 'manager/login/index',
  15. 'manager/login/mobile',
  16. 'manager/login/email',
  17. 'manager/login/send_code',
  18. 'manager/login/mobile_code',
  19. 'manager/citys/list',
  20. 'manager/login/wechat',
  21. 'manager/login/auth_rules',
  22. 'manager/upload/uploadimg',
  23. 'manager/upload/get_sign_url',
  24. 'manager/personnel_employee/personal_info',
  25. 'manager/login/wechat_bind',
  26. 'manager/citys/list_zoning',
  27. ];
  28. //默认配置
  29. protected $_config = [
  30. 'auth_on' => true, // 认证开关
  31. 'auth_type' => 1, // 认证方式,1为实时认证;2为登录认证。
  32. 'auth_group' => 'auth_group', // 用户组数据表名
  33. 'auth_group_access' => 'auth_group_access', // 用户-用户组关系表
  34. 'auth_rule' => 'auth_rule' // 权限规则表
  35. ];
  36. /**
  37. * $prefix表前缀
  38. */
  39. public function __construct()
  40. {
  41. // 判断配置
  42. if (config('AUTH_CONFIG')) {
  43. //可设置配置项 AUTH_CONFIG, 此配置项为数组。
  44. $this->_config = array_merge($this->_config, config('AUTH_CONFIG'));
  45. }
  46. }
  47. /**
  48. * Handle an incoming request.
  49. *
  50. * @param \Illuminate\Http\Request $request
  51. * @param \Closure $next
  52. * @return mixed
  53. */
  54. public function handle(Request $request, Closure $next)
  55. {
  56. // 当前路径
  57. $path = ltrim($request->getPathInfo(), '/');
  58. // 判断是否需要验证登录
  59. if (!in_array($path, $this->except)) {
  60. // 用户ID
  61. $uid = request('access_token.uid', 0);
  62. // 如果未登录
  63. if (!$uid) return json_send(['code' => 'no_login', 'msg' => '请登录账号', 'data' => ['请您登录']]);
  64. // 如果不是超级管理员
  65. if (!request('access_token.is_super', 0)) {
  66. // 进行验证
  67. if (!$this->check($path,$uid)) return json_send(['code' => 'error', 'msg' => '您没有操作权限', 'data' => ['没有操作权限']]);
  68. }
  69. }
  70. // 返回下一个闭包
  71. return $next($request);
  72. }
  73. /**
  74. * 检查权限
  75. * @param name string|array 需要验证的规则列表
  76. * @param uid int 认证用户的id
  77. * @return boolean 通过验证返回true;失败返回false
  78. */
  79. private function check($path, $uid)
  80. {
  81. // 未开启验证,直接通过
  82. if (!$this->_config['auth_on']) return true;
  83. $is_admin = request('access_token.is_admin');
  84. if($is_admin == 1){
  85. // 获取用户需要验证的所有有效规则列表
  86. $authList = (new AuthRule())->getAuthList($uid, 'manager');
  87. }else{
  88. // 获取用户需要验证的所有有效规则列表
  89. $authList = (new RolesAuthRule())->getAuthList($uid, 'manager');
  90. }
  91. // 切割path
  92. $path = explode('/', $path);
  93. // 没有控制器
  94. if (count($path) < 2) $path[] = 'index';
  95. // 没有方法
  96. if (count($path) < 3) $path[] = 'index';
  97. // 切割path
  98. $path = implode('/', $path);
  99. // 判断是否通过验证
  100. return in_array($path, $authList);
  101. }
  102. }