AuthMiddleware.php 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. <?php
  2. namespace app\middleware;
  3. use Shopwwi\WebmanAuth\Auth;
  4. use Shopwwi\WebmanAuth\JWT;
  5. use Webman\Http\Request;
  6. use Webman\Http\Response;
  7. use Webman\MiddlewareInterface;
  8. class AuthMiddleware implements MiddlewareInterface
  9. {
  10. public function process(Request $request, callable $handler): Response
  11. {
  12. try {
  13. $controller = new \ReflectionClass($request->controller);
  14. $noNeedLogin = $controller->getDefaultProperties()['noNeedLogin']??[];
  15. if (empty($noNeedLogin) || !in_array($request->action, $noNeedLogin)) {
  16. $type = $request->header('api-type','');
  17. if (empty($type)) return json(['code'=> 0,'msg'=> trans("error.param")]);
  18. $token = $request->header("Authorization","");
  19. if (empty($token)) return json(['code'=> 0,'msg'=> trans("error.request")]);
  20. (new JWT)->guard("admin")->verify();
  21. $user = (new Auth)->guard("admin")->user();
  22. if (empty($user)) return json(['code'=>401,'msg'=> trans("error.login")]);
  23. $request->user = $user->toArray();
  24. }
  25. } catch (\ReflectionException $exception) {
  26. return json(['code'=> 500,'msg'=> $exception->getMessage()]);
  27. }
  28. $response = $request->method() == 'OPTIONS' ? response('',204) : $handler($request);
  29. // 给响应添加跨域相关的http头
  30. $response->withHeaders([
  31. 'Access-Control-Allow-Credentials' => 'true',
  32. 'Access-Control-Allow-Origin' => $request->header('origin', '*'),
  33. 'Access-Control-Allow-Methods' => $request->header('access-control-request-method', '*'),
  34. 'Access-Control-Allow-Headers' => $request->header('access-control-request-headers', '*'),
  35. ]);
  36. return $response;
  37. }
  38. }