FooMiddleware.php 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Middleware\Auth;
  4. use Hyperf\HttpServer\Contract\RequestInterface;
  5. use Hyperf\HttpServer\Contract\ResponseInterface as HttpResponse;
  6. use Psr\Container\ContainerInterface;
  7. use Psr\Http\Message\ResponseInterface;
  8. use Psr\Http\Message\ServerRequestInterface;
  9. use Psr\Http\Server\MiddlewareInterface;
  10. use Psr\Http\Server\RequestHandlerInterface;
  11. use Phper666\JWTAuth\JWT;
  12. class FooMiddleware implements MiddlewareInterface
  13. {
  14. protected ContainerInterface $container;
  15. protected RequestInterface $request;
  16. protected HttpResponse $response;
  17. protected JWT $JWT;
  18. public function __construct(ContainerInterface $container, HttpResponse $response, RequestInterface $request,Jwt $JWT)
  19. {
  20. $this->container = $container;
  21. $this->response = $response;
  22. $this->request = $request;
  23. $this->JWT = $JWT;
  24. }
  25. public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
  26. {
  27. $header = $request->getHeaders();
  28. if($this->request->getUri()->getPath()=="/api/login" || $this->request->getUri()->getPath()=="/verifyCode"){
  29. return $handler->handle($request);
  30. }
  31. try {
  32. if($header && isset($header['token']) && $header['token'][0]!='null' && isset($header['token'][0])){
  33. $ver = $this->JWT->getClaimsByToken($header['token'][0]);
  34. if ($ver) {
  35. return $handler->handle($request);
  36. }
  37. }else{
  38. return $this->response->json(
  39. [
  40. 'code' => -1,
  41. 'data' => [],
  42. 'message' => 'token无效,请重新登录',
  43. ]
  44. );
  45. }
  46. }catch (\Exception $e){
  47. var_dump("错误消息:",$e->getMessage(),$e->getCode());
  48. return $this->response->json(
  49. [
  50. 'code' => $e->getCode(),
  51. 'data' => [],
  52. 'message' => $e->getMessage(),
  53. ]
  54. );
  55. }
  56. return $this->response->json(
  57. [
  58. 'code' => 1,
  59. 'data' => [],
  60. 'message' => 'token无效,请重新登录',
  61. ]
  62. );
  63. }
  64. }