当前位置: 首页 > news >正文

重学SpringBoot3-WebMvcAutoConfiguration类

重学SpringBoot3-WebMvcAutoConfiguration类

  • 是什么
  • 什么用
    • 生效条件
    • 作用
  • 自定义配置的三种方式
  • 自定义配置举例
    • 1. 自定义 DispatcherServlet 配置
    • 2. 静态资源配置
    • 3. 自定义MVC配置
    • 4. 消息转换器
    • 5. 异常处理

是什么

org.springframework.boot.autoconfigure.web.servlet.WebMvcAutoConfiguration

SpringBoot3 的 Web 开发能力,由 SpringMVC 提供,而 WebMvcAutoConfiguration 类是 SpringBoot 自动配置机制的一部分,专门用于配置 Spring MVC 的。这个类在 SpringBoot 应用程序中起着非常重要的作用,下面来看看它的详细作用。

什么用

生效条件

@AutoConfiguration(after = { DispatcherServletAutoConfiguration.class, TaskExecutionAutoConfiguration.class,ValidationAutoConfiguration.class }) // 在这些自动配置之后
@ConditionalOnWebApplication(type = Type.SERVLET) // 如果是web应用就生效
@ConditionalOnClass({ Servlet.class, DispatcherServlet.class, WebMvcConfigurer.class })  // 导入了这些类才生效
@ConditionalOnMissingBean(WebMvcConfigurationSupport.class) // 容器中没有这个Bean
@AutoConfigureOrder(Ordered.HIGHEST_PRECEDENCE + 10)
@ImportRuntimeHints(WebResourcesRuntimeHints.class)
public class WebMvcAutoConfiguration {// 
}

WebMvcAutoConfiguration类

上图 WebMvcAutoConfiguration 类在 SpringBoot 中通过条件注解来检测并应用自动配置。

作用

它主要负责以下配置:

  1. DispatcherServlet配置:它自动配置了 Spring MVC 的核心控制器,即DispatcherServlet。这包括将其注册到 Servlet 容器中以及相关的路径映射。

  2. 静态资源处理:它自动配置了静态资源的处理,比如 JavaScript、CSS 和图片等。这涉及到配置资源的位置以及缓存策略。

  3. Web MVC 配置:它自动配置了 Spring MVC 的基本设置,比如 URL 路径匹配、内容协商和视图解析器等。

  4. Message converters:根据classpath中的类,自动配置消息转换器,这对于RESTful应用程序处理JSON或XML数据尤其重要。

  5. 数据验证:如果 classpath 中存在验证器(例如Hibernate Validator),则自动配置数据验证。

  6. 国际化:自动配置消息源,以支持 i18n。

  7. 文件上传:如果相关类(如 MultipartResolver)在classpath中可用,它也会自动配置文件上传的支持。

  8. 异常处理:它自动配置了基础的异常处理,提供了一个默认的错误页面。

自定义配置的三种方式

在 Spring Boot 2.x 及之后的版本中,包括 Spring Boot 3,自动配置主要通过各种 @Configuration 类来完成,其中 WebMvcAutoConfiguration 是处理 Spring MVC 自动配置的关键类。这个类利用 Spring Framework 的条件注解(如 @ConditionalOnWebApplication@ConditionalOnClass@ConditionalOnMissingBean 等),根据应用程序的上下文和类路径的状态来自动配置 Spring MVC。

在 Spring Boot 3 中,如果想自定义 Spring MVC 的行为,通常会采取以下几种方法:

  1. 实现 WebMvcConfigurer 接口:通过创建一个配置类实现 WebMvcConfigurer 接口,并重写其中的方法,你可以自定义 Spring MVC 的配置,如拦截器、资源处理器、消息转换器等。这种方式不会替换掉 Spring Boot 的自动配置,而是在此基础上进行扩展。

    @Configuration
    public class MyMvcConfig implements WebMvcConfigurer {// 实现方法以自定义配置
    }
    
  2. 使用 properties 或 yaml 文件:通过在 application.propertiesapplication.yml 文件中设置相关的 Spring MVC 属性,你可以调整 Spring Boot 的自动配置行为。

  3. 使用 @EnableWebMvc:如果你添加 @EnableWebMvc 注解到你的配置类上,这将完全接管 Spring MVC 的配置,禁用 Spring Boot 的 MVC 自动配置。这种方式适用于需要完全控制 Spring MVC 配置的场景,但请注意,这样做意味着你需要手动配置 Spring MVC 需要的所有组件。

自定义配置举例

SpringBoot3 的自动配置尝试提供合理的默认配置,同时留下足够的灵活性,允许开发人员根据需要覆盖或扩展特定的配置。注意,如果你提供了自己的配置(比如自定义的DispatcherServlet、特定的WebMvcConfigurer实现等),Spring Boot的自动配置将适当地后退,允许使用你的自定义设置。

这只是 WebMvcAutoConfiguration 类的一个高层次概述。具体配置和细节可能会根据你的具体需求和 SpringBoot 的版本有所不同。下面继续深入了解WebMvcAutoConfiguration类在 SpringBoot3 中的作用,我们可以探讨一些具体的自动配置实例和细节。

1. 自定义 DispatcherServlet 配置

在Spring Boot中,DispatcherServlet 是自动配置的,但如果你想要自定义配置,比如修改默认的servlet映射(默认是"/"),你可以通过定义自己的ServletRegistrationBean 来实现。例如:

@Bean
public ServletRegistrationBean<DispatcherServlet> dispatcherServlet() {ServletRegistrationBean<DispatcherServlet> reg = new ServletRegistrationBean<>(new DispatcherServlet(), "/myapp/*");reg.setName("myDispatcherServlet");return reg;
}

2. 静态资源配置

SpringBoot 自动为静态资源服务提供了配置,默认情况下,它们可以从 /static/public/resources/META-INF/resources目录下被访问,见 org.springframework.boot.autoconfigure.web.WebProperties.Resources

public static class Resources {private static final String[] CLASSPATH_RESOURCE_LOCATIONS = { "classpath:/META-INF/resources/","classpath:/resources/", "classpath:/static/", "classpath:/public/" };}

但是,如果你需要修改这些默认设置或添加自定义缓存控制,你可以通过实现 WebMvcConfigurer 接口并重写相应的方法来实现,例如:

@Configuration
public class MyWebMvcConfig implements WebMvcConfigurer {@Overridepublic void addResourceHandlers(ResourceHandlerRegistry registry) {registry.addResourceHandler("/my-resources/**").addResourceLocations("classpath:/my-resources/").setCachePeriod(3600);}
}

当然也可以通过配置文件修改:

# 自定义多个静态资源文件夹位置
spring.web.resources.static-locations=classpath:/a/,classpath:/b/,classpath:/static/
#设置缓存
spring.web.resources.cache.period=3600

3. 自定义MVC配置

SpringBoot 允许通过实现 WebMvcConfigurer接口来自定义各种MVC设置。这包括拦截器、跨域请求处理、路径匹配配置等。例如,添加一个简单的拦截器可以如下实现:

@Configuration
public class MyWebMvcConfig implements WebMvcConfigurer {@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(new MyCustomInterceptor());}
}

4. 消息转换器

如果你需要添加或定制消息转换器,通过实现 WebMvcConfigurer 接口,并重写 configureMessageConverters 方法来添加或修改默认的消息转换器。这对于 REST API 开发尤其重要,你可能需要自定义 JSON 或 XML 的序列化和反序列化过程:

@Configuration
public class WebConfig implements WebMvcConfigurer {@Overridepublic void configureMessageConverters(List<HttpMessageConverter<?>> converters) {// 这里可以添加自定义的消息转换器// converters.add(new MyCustomMessageConverter());// 注意:如果你添加自己的转换器,确保不要调用默认转换器,除非你确实需要它们。// 调用 super.configureMessageConverters(converters) 会添加默认的转换器。}
}

5. 异常处理

虽然 SpringBoot 提供了默认的错误处理,但你可以通过注册 ErrorController@ControllerAdvice 来自定义错误响应。例如,可以创建一个用于捕获特定异常的 @ControllerAdvice

@ControllerAdvice
public class MyGlobalExceptionHandler {@ExceptionHandler(value = MyCustomException.class)public ResponseEntity<Object> handleCustomException(MyCustomException ex, WebRequest request) {// 处理异常return new ResponseEntity<>(...);}
}

以上示例展示了如何在 SpringBoot 中自定义和扩展 WebMVC 的各个方面。记住,尽管 SpringBoot 提供了许多默认的配置和自动化支持,但它也设计有足够的灵活性,允许开发者根据具体需求进行定制和优化。

这次先到这里,后续会对 SpringMVC 包含的组件继续进行介绍。

相关文章:

  • 使用 Docker 部署 MrDoc 在线文档管理系统
  • BUUCTF---[MRCTF2020]你传你呢1
  • 【CSS】(浮动定位)易忘知识点汇总
  • Ant Design Vue 修改Model弹框 样式不生效
  • Fastwhisper + Pyannote 实现 ASR + 说话者识别
  • SQL 的优化手段
  • YOLOv5创新改进:SPPF创新涨点篇 | SPPELAN:SPP创新结合ELAN ,效果优于SPP、SPPF| YOLOv9
  • XS2100S:IEEE 802.3af/at 兼容、用电设备接口控制器,集成功率MOSFET V1.0.3
  • 前端 css 实现标签的效果
  • django默认后台管理显示内容深化设置
  • Cluade3干货:超越GPT,模型特点分析+使用教程|2024年3月更新
  • 数据库之Oracle数据导入导出
  • 99.qt qml-单例程序实现
  • 开发Chrome扩展插件
  • 【golang】二叉树的遍历
  • [Vue CLI 3] 配置解析之 css.extract
  • [译] React v16.8: 含有Hooks的版本
  • - C#编程大幅提高OUTLOOK的邮件搜索能力!
  • C++11: atomic 头文件
  • js写一个简单的选项卡
  • 简析gRPC client 连接管理
  • 聊聊flink的TableFactory
  • 前端 CSS : 5# 纯 CSS 实现24小时超市
  • 使用 QuickBI 搭建酷炫可视化分析
  • 一起参Ember.js讨论、问答社区。
  • 应用生命周期终极 DevOps 工具包
  • # 数据结构
  • #在线报价接单​再坚持一下 明天是真的周六.出现货 实单来谈
  • $NOIp2018$劝退记
  • (1)虚拟机的安装与使用,linux系统安装
  • (11)MSP430F5529 定时器B
  • (java)关于Thread的挂起和恢复
  • (八)Flask之app.route装饰器函数的参数
  • (附源码)计算机毕业设计大学生兼职系统
  • (机器学习-深度学习快速入门)第三章机器学习-第二节:机器学习模型之线性回归
  • (深度全面解析)ChatGPT的重大更新给创业者带来了哪些红利机会
  • (转)JVM内存分配 -Xms128m -Xmx512m -XX:PermSize=128m -XX:MaxPermSize=512m
  • (转)Mysql的优化设置
  • (转)拼包函数及网络封包的异常处理(含代码)
  • (转)清华学霸演讲稿:永远不要说你已经尽力了
  • .net core webapi 大文件上传到wwwroot文件夹
  • .Net6使用WebSocket与前端进行通信
  • .NET多线程执行函数
  • .Net高阶异常处理第二篇~~ dump进阶之MiniDumpWriter
  • /etc/apt/sources.list 和 /etc/apt/sources.list.d
  • [ vulhub漏洞复现篇 ] struts2远程代码执行漏洞 S2-005 (CVE-2010-1870)
  • [30期] 我的学习方法
  • [Angular] 笔记 7:模块
  • [Angularjs]asp.net mvc+angularjs+web api单页应用之CRUD操作
  • [C#][opencvsharp]opencvsharp sift和surf特征点匹配
  • [C++] Windows中字符串函数的种类
  • [C++]C++入门--引用
  • [C++提高编程](三):STL初识
  • [CareerCup] 13.1 Print Last K Lines 打印最后K行
  • [Codeforces] number theory (R1600) Part.11