当前位置:   article > 正文

Spring Boot配置WebMvc_springboot webmvc

springboot webmvc

SpringBoot 抛弃了传统 xml 配置文件,SpringBoot 2.0 后,通过配置类(标注 @Configuration注解的类,相当于一个 xml 配置文件)以 JavaBean 形式进行相关配置。

SpringBoot对Spring MVC的会进行自动配置,这些默认的配置可以满足我们的大部分需求,但是我们对Spring MVC有时往往会有一些自己的需求定制。 我们也可以通过自定义配置类(标注 @Configuration注解 的类)并实现 WebMvcConfigurer 接口来定制 Spring MVC 配置,例如拦截器、格式化程序、视图控制器等等。

WebMvcConfigurer 是一个基于 Java 8 的接口,该接口定义了许多与 Spring MVC 相关的方法,其中大部分方法都是 default 类型的,且都是空实现。因此我们只需要定义一个配置类实现 WebMvcConfigurer 接口,并重写相应的方法便可以定制 Spring MVC 的配置。

WebMvcConfigurer常用的方法如下表所示:

方法 说明
default void configurePathMatch(PathMatchConfigurer configurer) {} HandlerMappings 路径的匹配规则。
default void configureContentNegotiation(ContentNegotiationConfigurer configurer) {} 内容协商策略(一个请求路径返回多种数据格式)。
default void configureAsyncSupport(AsyncSupportConfigurer configurer) {} 处理异步请求。
default void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {} 这个接口可以实现静态文件可以像 Servlet 一样被访问。
default void addFormatters(FormatterRegistry registry) {} 添加格式化器或者转化器。
default void addInterceptors(InterceptorRegistry registry) {} 添加 Spring MVC 生命周期拦截器,对请求进行拦截处理.
default void addResourceHandlers(ResourceHandlerRegistry registry) {} 添加或修改静态资源(例如图片,js,css 等)映射;
Spring Boot 默认设置的静态资源文件夹就是通过重写该方法设置的。
default void addCorsMappings(CorsRegistry registry) {} 处理跨域请求。
default void addViewControllers(ViewControllerRegistry registry) {} 主要用于实现无业务逻辑跳转,例如主页跳转,简单的请求重定向,错误页跳转等
default void configureViewResolvers(ViewResolverRegistry registry) {} 配置视图解析器,将 Controller 返回的字符串(视图名称),转换为具体的视图进行渲染。
default void addArgumentResolvers(List<HandlerMethodArgumentResolver> resolvers) {} 添加解析器以支持自定义控制器方法参数类型,实现该方法不会覆盖用于解析处理程序方法参数的内置支持;
要自定义内置的参数解析支持, 同样可以通过 RequestMappingHandlerAdapter 直接配置 RequestMappingHandlerAdapter 。
default void addReturnValueHandlers(List<HandlerMethodReturnValueHandler> handlers) {} 添加处理程序来支持自定义控制器方法返回值类型。使用此选项不会覆盖处理返回值的内置支持;
要自定义处理返回值的内置支持,请直接配置 RequestMappingHandlerAdapter。
default void configureMessageConverters(List<HttpMessageConverter<?>> converters) {} 用于配置默认的消息转换器(转换 HTTP 请求和响应)。
default void extendMessageConverters(List<HttpMessageConverter<?>> converters) {} 直接添加消息转换器,会关闭默认的消息转换器列表;
实现该方法即可在不关闭默认转换器的起提下,新增一个自定义转换器。
default void configureHandlerExceptionResolvers(List<HandlerExceptionResolver> resolvers) {} 配置异常解析器。
default void extendHandlerExceptionResolvers(List<HandlerExceptionResolver> resolvers) {} 扩展或修改默认的异常解析器列表。

在SpringBoot项目中,我们可以通过拓展SpringMVC和全面接管Spring MVC这两种方式来定制Spring MVC.

拓展Spring MVC

如果SpringBoot对Spring MVC的自动配置不能满足我们的需求的话,我们还可以通过实现 WebMvcConfigurer接口的配置类,并加上@Configuration 注解来拓展Spring MVC。这样不仅能够保留Spring Boot的Spring MVC的自动的默认配置,还可以额外增加自己的配置。

下面来演示一下:启动 Spring Boot,访问http://localhost:8080/loginhttp://localhost:8080/http://localhost:8080/index3 个 URL 都能跳转到登陆页 login.html。

假如我们要实现这样的一个功能:

创建一个任意名字的Spring Boot 项目,我这里叫demo01 ,然后创建一个config包,里面创建一个MyMvcConfig的类,这个类实现了WebMvcConfigurer接口。

在静态资源目录下创建两个html页面,分别时index.html和login.html :

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>index</title>
</head>
<body>
<h1>首页</h1>
</body>
</html>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>login</title>
</head>
<body>
<h1>登录页面</h1>
</body>
</html>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

然后我们编写配置类

package com.example.demo01.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class MyMvcConfig implements WebMvcConfigurer {

    @Override
    public void addViewControllers(ViewControllerRegistry registry){
        //当访问 “/” 或 “/index.html” 时,都直接跳转到登陆页面
        registry.addViewController("/").setViewName("login");
        registry.addViewController("/index").setViewName("login");
    }

}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

我们再编写一个controller:

    @GetMapping("/login")
    public String loginPage(){
        return "forward:/login.html";
    }
  • 1
  • 2
  • 3
  • 4

好的,我们运行一下我们的项目,会发现您会发现“http://localhost:8080/login”、“http://localhost:8080/”“http://localhost:8080/index”3 个 URL 都会返回login,如下所示:

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

全面接管Spring MVC

这个用法其实用得非常少,大家了解一下就好了。

再一些特殊的情况下,我们可能先要抛弃Spring Boot对Spring Boot的全部的自动配置,完全接管Spring MVC。此时我们可以自定义一个WebMvcConfigurer 的配置类,并在该类上标注@EnableWebMvc 注解。来实现完全接管Spring MVC 。(注意:完全接管Spring MVC后,SpringBoot对Spring MVC的自动配置将要全部失效。并且我们还要知道,Spring Boot 能够访问位于静态资源文件夹中的静态文件,这是因为 Spring Boot 对 Spring MVC 的默认自动配置中定义的,当我们全面接管 Spring MVC 后,Spring Boot 对 Spring MVC 的默认配置都会失效,此时再访问静态资源文件夹中的静态资源就会报 404 错误。)

下面举一个例子来演示如何使用:

1.在 MyMvcConfig 配置类上标注 @EnableWebMvc,除此之外其他文件都不做任何修改,代码如下。

package com.example.demo01.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

//实现 WebMvcConfigurer 接口可以来扩展 SpringMVC 的功能
// 完全接管SpringMVC
@EnableWebMvc
@Configuration
public class MyMvcConfig implements WebMvcConfigurer {

    @Override
    public void addViewControllers(ViewControllerRegistry registry){
        //当访问 “/” 或 “/index.html” 时,都直接跳转到登陆页面
        registry.addViewController("/").setViewName("login");
        registry.addViewController("/index").setViewName("login");
    }

}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22

好的,我们运行一下我们的项目,会发现您会发现“http://localhost:8080/login”、“http://localhost:8080/”“http://localhost:8080/index”3 个 URL 都会返回500或404。通过在properties中配置静态资源路径,可以解决这个问题。但我们最好还是不要使用这个方式,因为他会把SpringMVC得默认配置都给失效,会产生很多的bug。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/194574
推荐阅读
相关标签
  

闽ICP备14008679号