Spring Boot2 系列教程(十八)Spring Boot 中自定義 SpringMVC 配置

用過 Spring Boot 的小夥伴都知道,咱們只須要在項目中引入 spring-boot-starter-web 依賴,SpringMVC 的一整套東西就會自動給咱們配置好,可是,真實的項目環境比較複雜,系統自帶的配置不必定知足咱們的需求,每每咱們還須要結合實際狀況自定義配置。java

自定義配置就有講究了,因爲 Spring Boot 的版本變遷,加上這一塊自己就有幾個不一樣寫法,不少小夥伴在這裏容易搞混,今天鬆哥就來和你們說一說這個問題。web

概覽

首先咱們須要明確,跟自定義 SpringMVC 相關的類和註解主要有以下四個:spring

  • WebMvcConfigurerAdapter
  • WebMvcConfigurer
  • WebMvcConfigurationSupport
  • @EnableWebMvc

這四個中,除了第四個是註解,另外三個兩個類一個接口,裏邊的方法看起來好像都相似,可是實際使用效果卻大不相同,所以不少小夥伴容易搞混,今天鬆哥就來和你們聊一聊這個問題。ide

WebMvcConfigurerAdapter

咱們先來看 WebMvcConfigurerAdapter,這個是在 Spring Boot 1.x 中咱們自定義 SpringMVC 時繼承的一個抽象類,這個抽象類自己是實現了 WebMvcConfigurer 接口,而後抽象類裏邊都是空方法,咱們來看一下這個類的聲明:spring-boot

public abstract class WebMvcConfigurerAdapter implements WebMvcConfigurer {
    //各類 SpringMVC 配置的方法
}

再來看看這個類的註釋:this

/**
 * An implementation of {@link WebMvcConfigurer} with empty methods allowing
 * subclasses to override only the methods they're interested in.
 * @deprecated as of 5.0 {@link WebMvcConfigurer} has default methods (made
 * possible by a Java 8 baseline) and can be implemented directly without the
 * need for this adapter
 */

這段註釋關於這個類說的很明白了。同時咱們也看到,從 Spring5 開始,因爲咱們要使用 Java8,而 Java8 中的接口容許存在 default 方法,所以官方建議咱們直接實現 WebMvcConfigurer 接口,而不是繼承 WebMvcConfigurerAdapter 。spa

也就是說,在 Spring Boot 1.x 的時代,若是咱們須要自定義 SpringMVC 配置,直接繼承 WebMvcConfigurerAdapter 類便可。rest

WebMvcConfigurer

根據上一小節的解釋,小夥伴們已經明白了,WebMvcConfigurer 是咱們在 Spring Boot 2.x 中實現自定義配置的方案。code

WebMvcConfigurer 是一個接口,接口中的方法和 WebMvcConfigurerAdapter 中定義的空方法其實同樣,因此用法上來講,基本上沒有差異,從 Spring Boot 1.x 切換到 Spring Boot 2.x ,只須要把繼承類改爲實現接口便可。xml

鬆哥在以前的案例中(40 篇原創乾貨,帶你進入 Spring Boot 殿堂!),凡是涉及到自定義 SpringMVC 配置的地方,也都是經過實現 WebMvcConfigurer 接口來完成的。

WebMvcConfigurationSupport

前面兩個都好理解,還有一個 WebMvcConfigurationSupport ,這個又是幹什麼用的呢?

鬆哥以前有一篇文章中用過這個類,不知道小夥伴們有沒有留意,就是下面這篇:

  • 純 Java 代碼搭建 SSM 環境

這篇文章我放棄了 Spring 和 SpringMVC 的 xml 配置文件,轉而用 Java 代替這兩個 xml 配置。那麼在這裏我自定義 SpringMVC 配置的時候,就是經過繼承 WebMvcConfigurationSupport 類來實現的。在 WebMvcConfigurationSupport 類中,提供了用 Java 配置 SpringMVC 所須要的全部方法。咱們來看一下這個方法的摘要:

有一點眼熟,可能有小夥伴發現了,這裏的方法其實和前面兩個類中的方法基本是同樣的。

在這裏首先你們須要明確的是,WebMvcConfigurationSupport 類自己是沒有問題的,咱們自定義 SpringMVC 的配置是能夠經過繼承 WebMvcConfigurationSupport 來實現的。可是繼承 WebMvcConfigurationSupport 這種操做咱們通常只在 Java 配置的 SSM 項目中使用,Spring Boot 中基本上不會這麼寫,爲何呢?

小夥伴們知道,Spring Boot 中,SpringMVC 相關的自動化配置是在 WebMvcAutoConfiguration 配置類中實現的,那麼咱們來看看這個配置類的生效條件:

@Configuration
@ConditionalOnWebApplication(type = Type.SERVLET)
@ConditionalOnClass({ Servlet.class, DispatcherServlet.class, WebMvcConfigurer.class })
@ConditionalOnMissingBean(WebMvcConfigurationSupport.class)
@AutoConfigureOrder(Ordered.HIGHEST_PRECEDENCE + 10)
@AutoConfigureAfter({ DispatcherServletAutoConfiguration.class, TaskExecutionAutoConfiguration.class,
		ValidationAutoConfiguration.class })
public class WebMvcAutoConfiguration {
}

咱們從這個類的註解中能夠看到,它的生效條件有一條,就是當不存在 WebMvcConfigurationSupport 的實例時,這個自動化配置纔會生生效。所以,若是咱們在 Spring Boot 中自定義 SpringMVC 配置時選擇了繼承 WebMvcConfigurationSupport,就會致使 Spring Boot 中 SpringMVC 的自動化配置失效。

Spring Boot 給咱們提供了不少自動化配置,不少時候當咱們修改這些配置的時候,並非要全盤否認 Spring Boot 提供的自動化配置,咱們可能只是針對某一個配置作出修改,其餘的配置仍是按照 Spring Boot 默認的自動化配置來,而繼承 WebMvcConfigurationSupport 來實現對 SpringMVC 的配置會致使全部的 SpringMVC 自動化配置失效,所以,通常狀況下咱們不選擇這種方案。

在 Java 搭建的 SSM 項目中(純 Java 代碼搭建 SSM 環境),由於自己就沒什麼自動化配置,因此咱們使用了繼承 WebMvcConfigurationSupport。

@EnableWebMvc

最後還有一個 @EnableWebMvc 註解,這個註解很好理解,它的做用就是啓用 WebMvcConfigurationSupport。咱們來看看這個註解的定義:

/**
 * Adding this annotation to an {@code @Configuration} class imports the Spring MVC
 * configuration from {@link WebMvcConfigurationSupport}, e.g.:

能夠看到,加了這個註解,就會自動導入 WebMvcConfigurationSupport,因此在 Spring Boot 中,咱們也不建議使用 @EnableWebMvc 註解,由於它同樣會致使 Spring Boot 中的 SpringMVC 自動化配置失效。

總結

不知道上面的解釋小夥伴有沒有看懂?我再簡單總結一下:

  1. Spring Boot 1.x 中,自定義 SpringMVC 配置能夠經過繼承 WebMvcConfigurerAdapter 來實現。
  2. Spring Boot 2.x 中,自定義 SpringMVC 配置能夠經過實現 WebMvcConfigurer 接口來完成。
  3. 若是在 Spring Boot 中使用繼承 WebMvcConfigurationSupport 來實現自定義 SpringMVC 配置,或者在 Spring Boot 中使用了 @EnableWebMvc 註解,都會致使 Spring Boot 中默認的 SpringMVC 自動化配置失效。
  4. 在純 Java 配置的 SSM 環境中,若是咱們要自定義 SpringMVC 配置,有兩種辦法,第一種就是直接繼承自 WebMvcConfigurationSupport 來完成 SpringMVC 配置,還有一種方案就是實現 WebMvcConfigurer 接口來完成自定義 SpringMVC 配置,若是使用第二種方式,則須要給 SpringMVC 的配置類上額外添加 @EnableWebMvc 註解,表示啓用 WebMvcConfigurationSupport,這樣配置纔會生效。換句話說,在純 Java 配置的 SSM 中,若是你須要自定義 SpringMVC 配置,你離不開 WebMvcConfigurationSupport ,因此在這種狀況下建議經過繼承 WebMvcConfigurationSupport 來實現自動化配置。

不知道小夥伴們有沒有看懂呢?有問題歡迎留言討論。

 

相關文章
相關標籤/搜索