123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- <?php
- declare(strict_types=1);
- namespace App\Middleware\Auth;
- use Hyperf\HttpServer\Contract\RequestInterface;
- use Hyperf\HttpServer\Contract\ResponseInterface as HttpResponse;
- use Psr\Container\ContainerInterface;
- use Psr\Http\Message\ResponseInterface;
- use Psr\Http\Message\ServerRequestInterface;
- use Psr\Http\Server\MiddlewareInterface;
- use Psr\Http\Server\RequestHandlerInterface;
- use Hyperf\Context\Context;
- use Phper666\JWTAuth\JWT;
- class FooMiddleware implements MiddlewareInterface
- {
- protected ContainerInterface $container;
- protected RequestInterface $request;
- protected HttpResponse $response;
- protected JWT $JWT;
- public function __construct(ContainerInterface $container, HttpResponse $response, RequestInterface $request,Jwt $JWT)
- {
- $this->container = $container;
- $this->response = $response;
- $this->request = $request;
- $this->JWT = $JWT;
- }
- public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
- {
- $header = $request->getHeaders();
- // if($this->request->getUri()->getPath()=="/api/login" || $this->request->getUri()->getPath()=="/verifyCode" || $this->request->getUri()->getPath()=="/index"){
- // return $handler->handle($request);
- // }
- try {
- if($header && isset($header['token']) && $header['token'][0]!='null' && isset($header['token'][0])){
- $ver = $this->JWT->getClaimsByToken($header['token'][0]);
- // var_dump("中间件:",$ver);
- Context::set("UserId",$ver['uid']);
- if ($ver) {
- return $handler->handle($request);
- }
- }else{
- return $this->response->json(
- [
- 'code' => -1,
- 'data' => [],
- 'message' => 'token无效,请重新登录',
- ]
- );
- }
- }catch (\Exception $e){
- var_dump("错误消息:",$e->getMessage(),$e->getCode());
- return $this->response->json(
- [
- 'code' => $e->getCode(),
- 'data' => [],
- 'message' => $e->getMessage(),
- ]
- );
- }
- return false;
- }
- }
|