AuthMiddleware.php 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeshop100%开源免费商用商城系统
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | 商业版本务必购买商业授权,以免引起法律纠纷
  8. // | 禁止对系统程序代码以任何目的,任何形式的再发布
  9. // | gitee下载:https://gitee.com/likeshop_gitee
  10. // | github下载:https://github.com/likeshop-github
  11. // | 访问官网:https://www.likeshop.cn
  12. // | 访问社区:https://home.likeshop.cn
  13. // | 访问手册:http://doc.likeshop.cn
  14. // | 微信公众号:likeshop技术社区
  15. // | likeshop团队 版权所有 拥有最终解释权
  16. // +----------------------------------------------------------------------
  17. // | author: likeshopTeam
  18. // +----------------------------------------------------------------------
  19. declare (strict_types=1);
  20. namespace app\businessapi\http\middleware;
  21. use app\common\{
  22. cache\AdminAuthCache,
  23. service\JsonService
  24. };
  25. class AuthMiddleware
  26. {
  27. /**
  28. * @notes 权限验证
  29. * @param $request
  30. * @param \Closure $next
  31. * @return mixed
  32. * @author 令狐冲
  33. * @date 2021/7/2 19:29
  34. */
  35. public function handle($request, \Closure $next)
  36. {
  37. //不登录访问,无需权限验证
  38. if ($request->controllerObject->isNotNeedLogin()) {
  39. return $next($request);
  40. };
  41. //系统默认超级管理员,无需权限验证
  42. if (1 === $request->adminInfo['root'] ) {
  43. return $next($request);
  44. }
  45. $accessUri = strtolower($request->controller() . '/' . $request->action());//当前访问uri
  46. $adminAuthCache = new AdminAuthCache($request->adminInfo['admin_id']);
  47. $allUri = $adminAuthCache->getAllUri()['action_auth'] ?? [];
  48. //判断该当前访问的uri是否存在,不存在无需验证
  49. if (!in_array($accessUri, $allUri)) {
  50. return $next($request);
  51. }
  52. //管理员访问的uri判断
  53. $AdminUris = $adminAuthCache->getAdminUri()['action_auth'] ?? [];
  54. if (in_array($accessUri, $AdminUris)) {
  55. return $next($request);
  56. }
  57. return JsonService::fail('权限不足,无法访问或操作');
  58. }
  59. }