Spring MVC 具体的工作原理?
理解这些组件的作用以及它们之间的协作关系,就能够理解 Spring MVC 的工作原理。HandlerMapping 会遍历已注册的 HandlerMapping 实现,根据请求的 URL 和配置,找到最合适的 HandlerExecutionChain (处理器执行链)。因为 Handler 的类型有很多种 (Controller 方法、HttpRequestHandler、Servlet 等)
Spring MVC 的工作原理可以用一个流程图来概括,它主要负责接收用户的请求,处理请求,并将处理结果返回给用户。 我将从请求的入口开始,逐步解释 Spring MVC 的处理流程。
1. 接收请求:
当 Tomcat (或其他 Servlet 容器) 接收到客户端发送的 HTTP 请求时,会将请求交给 DispatcherServlet 处理。 DispatcherServlet 是 Spring MVC 的核心组件,也是前端控制器 (Front Controller) 模式的实现。 在 Spring MVC 应用启动时,DispatcherServlet 会被初始化并加载 Spring MVC 的配置信息,例如 HandlerMapping、ViewResolver 等。
2. HandlerMapping 处理请求映射:
DispatcherServlet 接收到请求后,并不会直接处理,而是将请求交给 HandlerMapping 组件。 HandlerMapping 的作用是根据请求的 URL 查找匹配的 Handler (处理器)。 Handler 可以是一个 Controller 中的方法,也可以是一个实现了 HttpRequestHandler
或 Servlet
接口的类。
Spring MVC 提供了多种 HandlerMapping 的实现,例如:
- RequestMappingHandlerMapping: 最常用的 HandlerMapping,基于
@RequestMapping
注解进行请求映射。 - BeanNameUrlHandlerMapping: 根据 Bean 的名称 (URL) 进行请求映射。
- SimpleUrlHandlerMapping: 通过简单的 URL 映射配置进行请求映射。
HandlerMapping 会遍历已注册的 HandlerMapping 实现,根据请求的 URL 和配置,找到最合适的 HandlerExecutionChain (处理器执行链)。 HandlerExecutionChain 中包含了 Handler 本身以及一系列的 HandlerInterceptor (处理器拦截器)。
3. HandlerAdapter 执行 Handler:
DispatcherServlet 拿到 HandlerExecutionChain 后,需要通过 HandlerAdapter 组件来执行具体的 Handler。 因为 Handler 的类型有很多种 (Controller 方法、HttpRequestHandler、Servlet 等),HandlerAdapter 的作用就是适配不同类型的 Handler,以统一的方式进行调用。
Spring MVC 也提供了多种 HandlerAdapter 的实现,例如:
- RequestMappingHandlerAdapter: 用于处理
@RequestMapping
注解标记的 Controller 方法。 - HttpRequestHandlerAdapter: 用于处理实现了
HttpRequestHandler
接口的 Handler。 - SimpleServletHandlerAdapter: 用于处理 Servlet 类型的 Handler。
HandlerAdapter 会调用 Handler 中的处理方法,例如 Controller 中的方法,并负责处理方法的参数绑定、数据转换、方法返回值处理等。
4. Handler 返回 ModelAndView:
Handler 执行完成后,通常会返回一个 ModelAndView 对象。 ModelAndView 包含了两个关键信息:
- Model: 模型数据,用于传递给视图的数据。 可以是一个 Map,或者自定义的 Model 对象。
- View: 视图对象或视图名称,用于指定如何渲染模型数据。 视图可以是 JSP 页面、Thymeleaf 模板、FreeMarker 模板,也可以是 JSON 视图、XML 视图等。
如果 Handler 方法使用了 @ResponseBody
注解,或者返回的是 ResponseEntity 等类型, HandlerAdapter 会将返回值直接写入响应体,而不会返回 ModelAndView。 这种情况下,通常用于返回 JSON 或 XML 数据,例如构建 RESTful API。
5. ViewResolver 解析视图:
DispatcherServlet 接收到 ModelAndView 对象后,如果 ModelAndView 中包含的是视图名称,则需要通过 ViewResolver 组件来解析视图。 ViewResolver 的作用是将视图名称解析为具体的 View 对象。
Spring MVC 提供了多种 ViewResolver 的实现,例如:
- InternalResourceViewResolver: 用于解析 JSP 页面。
- ThymeleafViewResolver: 用于解析 Thymeleaf 模板。
- FreeMarkerViewResolver: 用于解析 FreeMarker 模板。
- ContentNegotiatingViewResolver: 根据客户端请求的
Accept
头部信息,选择合适的 ViewResolver 和 View,用于内容协商。
ViewResolver 会遍历已注册的 ViewResolver 实现,根据视图名称和配置,找到合适的 View 对象。
6. View 渲染视图:
DispatcherServlet 拿到 View 对象后,会调用 View 的 render()
方法来渲染视图。 render()
方法会将 ModelAndView 中的 Model 数据和视图模板结合起来,生成最终的 HTML 或其他格式的响应内容。
7. 返回响应:
View 渲染完成后,DispatcherServlet 会将渲染结果 (例如 HTML 内容) 写入 HTTP 响应体,并返回给客户端。 至此,一个完整的 Spring MVC 请求处理流程就结束了。
代码示例 (简化 Controller):
@Controller
public class HelloController {
@RequestMapping("/hello")
public ModelAndView hello(String name) {
ModelAndView mv = new ModelAndView();
mv.addObject("message", "Hello, " + name + "!"); // 添加模型数据
mv.setViewName("hello"); // 设置视图名称 (例如 "hello.jsp")
return mv;
}
}
总结:
Spring MVC 的工作流程可以概括为:
- DispatcherServlet 接收请求。
- HandlerMapping 查找 Handler。
- HandlerAdapter 执行 Handler。
- Handler 返回 ModelAndView。
- ViewResolver 解析 View。
- View 渲染视图。
- DispatcherServlet 返回响应。
这个流程的核心组件包括 DispatcherServlet、HandlerMapping、HandlerAdapter、Controller、ModelAndView、ViewResolver 和 View。 理解这些组件的作用以及它们之间的协作关系,就能够理解 Spring MVC 的工作原理。 Spring MVC 的设计非常灵活和可扩展,允许开发者自定义 HandlerMapping、HandlerAdapter、ViewResolver 和 View 等组件,以满足不同的需求。
更多推荐
所有评论(0)