AuthLogin.php 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Helpers\Jwt;
  4. use Closure;
  5. use Illuminate\Auth\Middleware\Authenticate as Middleware;
  6. class AuthLogin extends Middleware
  7. {
  8. /**
  9. * 执行句柄
  10. * @param \Illuminate\Http\Request $request
  11. * @param Closure $next
  12. * @param mixed ...$guards
  13. * @return mixed
  14. * @throws \Illuminate\Auth\AuthenticationException
  15. * @since 2020/8/31
  16. * @author wesmiler
  17. */
  18. public function handle($request, Closure $next, ...$guards)
  19. {
  20. $response = $next($request);
  21. $action = app('request')->route()->getAction();
  22. $controller = class_basename($action['controller']);
  23. list($controller, $action) = explode('@', $controller);
  24. $noLoginActs = ['LoginController','TestController','AuthController','NotifyController','IndexController'];
  25. $token = $request->headers->get('Authorization');
  26. if (strpos($token, 'Bearer ') !== false) {
  27. $token = str_replace("Bearer ", null, $token);
  28. if($token == 'test123'){
  29. $userId = 58;
  30. }else{
  31. // JWT解密token
  32. $jwt = new Jwt('jwt_wx');
  33. $userId = $jwt->verifyToken($token);
  34. }
  35. } else {
  36. $userId = 0;
  37. }
  38. if (!$userId && !in_array($controller, $noLoginActs)) {
  39. // 判断用户未登录就跳转至登录页面
  40. // 在这里可以定制你想要的返回格式, 亦或者是 JSON 编码格式
  41. return response()->json(message("请登录", false, null, 10001));
  42. }
  43. //如果已登录则执行正常的请求
  44. return $response;
  45. }
  46. }