Bootstrap

‌Spring MVC的主要组件有哪些?

前言

SpringMVC的核心组件包括DispatcherServlet、Controller、HandlerMapping、HandlerAdapter、ViewResolver、ModelAndView等,它们协同工作以支持基于MVC架构的Web应用程序开发。这些组件使得开发人员能够以一种声明式和模块化的方式构建Web应用程序,处理HTTP请求,执行业务逻辑,并生成响应。理解这些核心组件对于学习SpringMVC至关重要。

Spring MVC(Model-View-Controller)框架由多个关键组件组成,这些组件协同工作,实现从请求到响应的完整流程。

‌一、Spring MVC的组件

‌Spring MVC的主要组件包括以下几种‌:

1)DispatcherServlet‌作为前端控制器,负责接收所有的HTTP请求,并将请求转发到相应的处理器。它不需要程序员开发,是Spring写好的一个Servlet‌。

‌2)HandlerMapping‌处理器映射器,根据请求的URL来查找对应的处理器(Controller)。它不需要程序员开发,但需要加入到IoC容器中‌。

‌3)HandlerAdapter‌处理器适配器,负责调用处理器的具体方法。它也需要注册到容器中,并且需要按照适配器要求的规则编写处理器‌。

‌4)Controller‌控制器,处理业务逻辑,调用服务层,并返回模型数据和视图。这需要程序员开发‌。

‌5)ViewResolver‌:视图解析器,将逻辑视图名解析为实际的视图对象。它不需要程序员开发,但需要配置‌。

6‌)View‌:视图,负责渲染最终的页面。这需要程序员开发,支持不同的视图类型(如JSP、Freemarker等)‌。

7‌)Interceptor‌:拦截器,用于在请求处理前后进行拦截处理,如日志记录、权限检查等。这需要程序员开发‌。

8‌)DataBinder‌:数据绑定器,用于将请求参数绑定到模型对象上‌。

‌9)HttpMessageConverter‌消息转换器,用于处理HTTP请求和响应的媒体类型转换‌。

这些组件共同工作,构成了Spring MVC的核心功能,使得开发者能够高效地开发Web应用程序。每个组件都可以根据需求进行定制和扩展,以满足特定的应用场景。

二、Spring MVC 源码分析 - HandlerAdapter 组件

HandlerAdapter 组件,处理器的适配器。因为处理器 handler 的类型是 Object 类型,需要有一个调用者来实现handler 是怎么被执行。Spring 中的处理器的实现多变,比如用户的处理器可以实现 Controller 接口或者 HttpRequestHandler 接口,也可以用 @RequestMapping 注解将方法作为一个处理器等,这就导致 Spring MVC 无法直接执行这个处理器。所以这里需要一个处理器适配器,由它去执行处理器。

三、HandlerAdapter 组件之 HttpMessageConverter

在 HandlerAdapter 执行处理器的过程中,具体的执行过程交由 ServletInvocableHandlerMethod对象来完成,其中需要先通过 HandlerMethodArgumentResolver 参数解析器从请求中解析出方法的入参,然后再通过反射机制调用对应的方法,获取到执行结果后需要通过 HandlerMethodReturnValueHandler 结果处理器来进行处理。在处理返回结果的过程中,可能需要通过 HttpMessageConverter 消息转换器将返回结果设置到响应体中,当然也可能需要通过它从请求体获取入参。
在使用 Spring MVC 时, @RequestBody 和 @ResponseBody 两个注解,分别完成请求报文到 Java 对象、Java对象到响应报文的转换,底层的实现就是通过 Spring 3.x 中引入的HttpMessageConverter 消息转换机制来实现的。

在 HttpMessageConverter 的 read 方法中,有一个 HttpInputMessage 的形参,它正是 SpringMVC 的消息转换器所作用的受体请求消息的内部抽象,消息转换器从请求消息中按照规则提取消息,转换为方法形参中声明的对象。

在 HttpMessageConverter 的 write 方法中,有一个 HttpOutputMessage 的形参,它正是 Spring MVC 的消息转换器所作用的受体响应消息的内部抽象,消息转换器将响应消息按照一定的规则写到响应报文中。

HttpMessageConverter 接口

org.springframework.http.converter.HttpMessageConverter :对消息转换器最高层次的接口抽象,描述了一个消息转换器的一般特征。

public interface HttpMessageConverter<T> {
    boolean canRead(Class<?> clazz, @Nullable MediaType mediaType);

    boolean canWrite(Class<?> clazz, @Nullable MediaType mediaType);

    List<MediaType> getSupportedMediaTypes();

    default List<MediaType> getSupportedMediaTypes(Class<?> clazz) {
        return !this.canRead(clazz, (MediaType)null) && !this.canWrite(clazz, (MediaType)null) ? Collections.emptyList() : this.getSupportedMediaTypes();
    }

    T read(Class<? extends T> clazz, HttpInputMessage inputMessage) throws IOException, HttpMessageNotReadableException;

    void write(T t, @Nullable MediaType contentType, HttpOutputMessage outputMessage) throws IOException, HttpMessageNotWritableException;
}

总结

Spring 框架是高度可配置的,而且包含多种视图技术,例如 JavaServer Pages(JSP)技术、Velocity;Spring MVC 框架并不知道使用的视图,所以不会强迫开发者只使用 JSP 技术。Spring MVC 分离了控制器、模型对象、过滤器以及处理程序对象的角色,这种分离让它们更容易进行定制。

以上这些组件共同构成了 Spring MVC 的核心,它们使得开发人员能够以一种声明式和模块化的方式构建 Web 应用程序。通过这些组件,Spring MVC 能够处理 HTTP 请求,执行业务逻辑,并生成响应。

;