AdminAuthTokenMiddleware.php 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2020 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\http\middleware\admin;
  12. use app\Request;
  13. use app\services\system\admin\SystemAdminServices;
  14. use Closure;
  15. use Psr\SimpleCache\InvalidArgumentException;
  16. use qiniu\exceptions\AdminException;
  17. use qiniu\interfaces\MiddlewareInterface;
  18. use think\facade\Config;
  19. /**
  20. * 后台登陆验证中间件
  21. * Class AdminAuthTokenMiddleware
  22. * @package app\http\middleware\admin
  23. */
  24. class AdminAuthTokenMiddleware implements MiddlewareInterface
  25. {
  26. /**
  27. * @param Request $request
  28. * @param Closure $next
  29. * @return mixed
  30. * @throws InvalidArgumentException
  31. */
  32. public function handle(Request $request, Closure $next)
  33. {
  34. $token = trim(ltrim($request->header(Config::get('cookie.token_name', 'Authori-zation')), 'Bearer'));
  35. /** @var SystemAdminServices $service */
  36. $service = app()->make(SystemAdminServices::class);
  37. $adminInfo = $service->parseToken($token);
  38. $request->setAdmin($adminInfo);
  39. if ($request->adminStoreId() > 0) {
  40. throw new AdminException('账号错误');
  41. }
  42. return $next($request);
  43. }
  44. }