WebUser.php 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Helpers\Jwt;
  4. use App\Services\ConfigService;
  5. use App\Services\RedisService;
  6. use Closure;
  7. use Illuminate\Auth\Middleware\Authenticate as Middleware;
  8. class WebUser extends Middleware
  9. {
  10. /**
  11. * 执行句柄
  12. * @param \Illuminate\Http\Request $request
  13. * @param Closure $next
  14. * @param mixed ...$guards
  15. * @return mixed
  16. * @throws \Illuminate\Auth\AuthenticationException
  17. * @since 2020/8/31
  18. * @author wesmiler
  19. */
  20. public function handle($request, Closure $next, ...$guards)
  21. {
  22. $token = $request->headers->get('Authorization');
  23. if (strpos($token, 'Bearer ') !== false) {
  24. $token = str_replace("Bearer ", null, $token);
  25. $token = trim($token);
  26. if($token){
  27. // JWT解密token
  28. $jwt = new Jwt('jwt_lgx_app');
  29. $userId = $jwt->verifyToken($token);
  30. }else{
  31. return response()->json(message(1035, false, [], 403))->setEncodingOptions(256);
  32. }
  33. } else {
  34. $userId = 0;
  35. }
  36. $request->headers->set('token_uid' , $userId);
  37. //如果已登录则执行正常的请求
  38. return $next($request);
  39. }
  40. }