CheckToken.php 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Models\User;
  4. use App\Models\UserSession;
  5. use Closure;
  6. use Illuminate\Http\Request;
  7. class CheckToken
  8. {
  9. /**
  10. * 处理传入请求
  11. *
  12. * @param \Illuminate\Http\Request $request
  13. * @param \Closure $next
  14. * @return mixed
  15. */
  16. public function handle(Request $request, Closure $next)
  17. {
  18. // 1. 从请求头获取 token(header 名称:token / Token 都支持)
  19. $token = $request->header('token');
  20. // 2. 如果请求头没有 token,直接返回未授权
  21. if (empty($token)) {
  22. return response()->json([
  23. 'code' => 401,
  24. 'msg' => lang('请携带token访问')
  25. ], 401);
  26. }
  27. // 3. 查询 user_session:token 存在 + 未过期
  28. $session = UserSession::where('token', $token)
  29. ->where('expire_time', '>', now()) // 过期时间 > 当前时间 = 未过期
  30. ->first();
  31. // 4. 会话不存在或已过期
  32. if (!$session) {
  33. return response()->json([
  34. 'code' => 401,
  35. 'msg' => lang('token无效或已过期')
  36. ], 401);
  37. }
  38. // 5. 查询对应用户信息
  39. $user = User::find($session->user_id);
  40. // 6. 用户不存在
  41. if (!$user) {
  42. return response()->json([
  43. 'code' => 401,
  44. 'msg' => lang('用户不存在')
  45. ], 401);
  46. }
  47. // 7. 把用户信息赋值给 $request->user
  48. $request->user = $user;
  49. // 8. 放行请求,进入控制器
  50. return $next($request);
  51. }
  52. }