一、Spring MVC回顾
Spring MVC是一种常用的Java Web框架,它提供了一种基于MVC模式的开发方式,可以方便地实现Web应用程序。在Spring MVC中,WebMvcConfigurer是一种常用的配置方式,可以允许我们自定义Spring MVC的行为,比如添加拦截器、消息转换器等。
可以看到WebMvcConfigurer是一个非常灵活和强大的工具,它可以让我们实现自己的业务需求并提高代码的可读性和可维护性。而且我们在Spring、SpringBoot都可以很简单的使用WebMvcConfigurer,下面主要在SpringBoot中说明配置。
二、配置Spring MVC
官方建议:直接创建一个MyMvcConfig类,在类上加上@Configuration
注解,并且实现WebMvcConfigurer
接口(相当与SpringMVC项目中的applicationContext.xml文件 ),并且不能使用@EnableWebMvc
注解
java
@Configuration
public class MyMvcConfig implements WebMvcConfigurer {
}
为什么不能使用@EnableWebMvc注解
@EnableWebMvc导入了DelegatingWebMvcConfiguration类

DelegatingWebMvcConfiguration又继承了WebMvcConfigurationSupport

但是我们查看WebMvcAutoConfiguration类发现添加了@ConditionalOnMissingBean(WebMvcConfigurationSupport.class),那么在使用@EnableWebMvc注解时,WebMvcAutoConfiguration这个自动配置类就不会在进行加载
如果需要全面接管SpringMVC可以使用该注解,当然在开发中,不推荐使用全面接管SpringMVC
三、配置拦截器
配置拦截器实现登录拦截,需要实现HandlerInterceptor 接口并且实现preHandle方法即可
java
public class LoginInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
HttpSession session = request.getSession();
if (session.getAttribute("loginUser") == null) {
request.setAttribute("msg", "身份未验证,请先登录");
request.getRequestDispatcher("/index.html").forward(request, response);
return false;
} else {
return true;
}
}
}
在SpirngMVC配置文件中添加拦截器,即可实现登录拦截。(相当于注册拦截器)
java
@Override
// 重写addInterceptors方法,用于添加拦截器
public void addInterceptors(InterceptorRegistry registry) {
// 添加LoginInterceptor拦截器
registry.addInterceptor(new LoginInterceptor())
// 拦截所有路径
.addPathPatterns("/**")
// 排除指定路径
.excludePathPatterns("/index.html", "/", "/user/login", "/css/**", "/img/**", "/js/**");
}