接口请求处理流程

概述

本文档详细描述了 /app/login 接口的请求处理流程,包括各个过滤器和拦截器的执行顺序和作用。

请求处理流程

1. 请求进入过滤器链(Filter Chain)

当客户端发起 /app/login 请求时,会经过以下过滤器:

A. CorsFilter(跨域过滤器)
  • 首先处理跨域请求
  • 在 SecurityConfig 中配置为最先执行:httpSecurity.addFilterBefore(corsFilter, JwtAuthenticationTokenFilter.class)
B. RepeatableFilter(可重复读取过滤器)
  • 注册顺序为 LOWEST_PRECEDENCE(最低优先级,最后执行)
  • 检查请求是否为 JSON 类型:StringUtils.startsWithIgnoreCase(request.getContentType(), MediaType.APPLICATION_JSON_VALUE)
  • 如果是 JSON 请求,则包装成 RepeatedlyRequestWrapper,使请求体可以被重复读取
  • 主要作用:解决流只能读取一次的问题,便于后续处理
C. JwtAuthenticationTokenFilter(JWT 认证过滤器)
  • UsernamePasswordAuthenticationFilter 之前执行
  • 从请求头中提取 JWT Token
  • 验证 Token 有效性
  • 将用户信息存储到 Spring Security 上下文中
  • 但是 /app/login 路径在 SecurityConfig 中被配置为允许匿名访问,因此这个过滤器可能不会对登录请求进行实际的认证操作

2. Spring MVC 处理流程

A. DispatcherServlet
  • Spring MVC 的核心前端控制器
  • 接收所有请求并分发给相应的处理器
B. HandlerMapping
  • 根据请求路径 /app/login 和 POST 方法找到对应的控制器方法
  • 映射到 LoginAppController.loginApp() 方法
C. 拦截器(Interceptors)
  • 如果有配置拦截器,会在 Controller 方法执行前后进行拦截处理
D. 数据绑定和校验
  • 将请求体 JSON 数据绑定到 LoginAppParam 对象
  • 执行参数校验(由于使用了 @Validated 注解)

3. 控制器处理

LoginAppController.loginApp()
  • 路径:POST /app/login
  • 方法:接收 @RequestBody LoginAppParam param
  • 调用 loginAppService.loginApp(param) 服务方法
  • 返回 R.ok("登录成功")

4. 服务层处理

LoginAppService.loginApp()
  • 获取手机号和密码
  • 调用 getHcry2025s(mobile) 查询核查人员表
  • 调用 userService.selectUserByUserName(mobile, UserTypeEnum.WEB_SYSTEM_USER.getCode()) 查询 Web 用户
  • 验证登录凭据
  • 记录登录日志

5. 数据访问层

  • 通过 MyBatis 访问数据库
  • 执行相应的 SQL 查询语句

6. 响应返回

  • 返回 JSON 格式的响应
  • {"code": 200, "msg": "登录成功", "data": null}

特殊说明

  1. 匿名访问权限 :在 SecurityConfig 中,/app/** 路径被配置为允许匿名访问,这意味着登录请求不会受到 JWT 认证过滤器的限制。

  2. 过滤器执行顺序

    • CorsFilter(最高优先级)
    • 其他 Spring Security 过滤器
    • JwtAuthenticationTokenFilter
    • RepeatableFilter(最低优先级)
  3. 请求体重复读取:RepeatableFilter 的主要目的是确保请求体可以被多次读取,这对于日志记录、参数解析等操作非常有用。

相关推荐
hoho_121 小时前
如何替换jar包中依赖的其他jar
java·pycharm·jar
布朗克1681 小时前
23 泛型——类型安全的参数化编程
java·泛型
我命由我123452 小时前
Kotlin 开发 - Kotlin 反引号转义关键字
android·java·开发语言·java-ee·kotlin·android jetpack·android runtime
艾利克斯冰2 小时前
Java设计模式-工厂方法模式
java
中草药z2 小时前
【RAG】工程化实战:全链路原理复盘 + 方案选型 + 实战高阶玩法
java·深度学习·机器学习·阿里云·rag·springai
学计算机的计算基2 小时前
MySQL 性能调优面试复习:Explain、索引、慢查询、缓存和架构优化
java·数据库·笔记·mysql
Hillain2 小时前
软件设计师设计模式
java·开发语言·经验分享·笔记·算法·设计模式·软考
影寂ldy2 小时前
C# 泛型方法
java·前端·c#
摇滚侠2 小时前
Spring 零基础入门到进阶 IOC 概述 11 - 13
java·后端·spring