目录
2、创建WebConfig配置类,代替springMVC的配置文件
3、创建SpringConfig配置类,代替spring的配置文件
目的:使用配置类和注解代替web.xml和SpringMVC配置文件的功能
1、创建初始化类,代替 web.xml
在Servlet3.0环境中,容器会在类路径中查找实现 javax.servlet.ServletContainerInitializer 接口的类,如果找到的话就用它来配置 Servlet 容器。 Spring提供了这个接口的实现,名为 SpringServletContainerInitializer,这个类反过来又会查找实现 WebApplicationInitializer 的类并将配置的任务交给它们来完成。Spring3.2 引入了一个便利的 WebApplicationInitializer 基础实现,名为 AbstractAnnotationConfigDispatcherServletInitializer,当我们的类扩展了 AbstractAnnotationConfigDispatcherServletInitializer 并将其部署到Servlet3.0容器的时候,容器会自动发现它,并用它来配置Servlet上下文。
① 新建一个空的 maven 模块,将之前 pom.xml 复制过来。在 src/main 下创建 webapp 目录,在 webapp 下创建 WEB-INF。
② 创建配置类 WebInit 类,由于 getRootConfigClasses 和 getServletConfigClasses 需要返回配置类的class类对象,所以需要先创建对应的配置类,这里创建 WebConfig 和 SpringConfig 配置类
/**
* @Author zhang
* @Date 2022/3/8 - 23:16
* @Version 1.0
*/
// web工程的初始化类,用来代替web.xml
public class WebInit extends AbstractAnnotationConfigDispatcherServletInitializer {
/**
* 指定根配置,也就是spring的配置类
* @return
*/
@Override
protected Class<?>[] getRootConfigClasses() {
return new Class[]{SpringConfig.class};
}
/**
* 指定springMVC的配置类
* @return
*/
@Override
protected Class<?>[] getServletConfigClasses() {
return new Class[]{WebInit.class};
}
/**
* 指定DispatcherServlet的映射规则,即url-pattern
* @return
*/
@Override
protected String[] getServletMappings() {
return new String[]{"/"};
}
/**
* 注册过滤器
* @return
*/
@Override
protected Filter[] getServletFilters() {
CharacterEncodingFilter characterEncodingFilter = new CharacterEncodingFilter();
characterEncodingFilter.setEncoding("UTF-8");
characterEncodingFilter.setForceResponseEncoding(true);
HiddenHttpMethodFilter hiddenHttpMethodFilter = new HiddenHttpMethodFilter();
return new Filter[]{characterEncodingFilter, hiddenHttpMethodFilter};
}
}
2、创建WebConfig配置类,代替springMVC的配置文件
/**
* 代替springMVC的配置文件:
* 1.扫描组件
* 2.视图解析器
* 3.view-controller
* 4.default-servlet-handler
* 5.mvc注解驱动
* 6.文件上传解析器
* 7.异常处理
* 8.拦截器
*/
@Configuration //将当前类标识为一个配置类
@ComponentScan("com.zyj.mvc.controller") //1.扫描组件
@EnableWebMvc //5.mvc注解驱动
public class WebConfig implements WebMvcConfigurer {
/**
* 7.异常处理
* @param resolvers
*/
@Override
public void configureHandlerExceptionResolvers(List<HandlerExceptionResolver> resolvers) {
SimpleMappingExceptionResolver exceptionResolver = new SimpleMappingExceptionResolver();
Properties properties = new Properties();
properties.setProperty("java.lang.ArithmeticException", "error");
exceptionResolver.setExceptionMappings(properties);
exceptionResolver.setExceptionAttribute("exception");
resolvers.add(exceptionResolver);
}
/**
* 6.文件上传解析器
* @return
*/
@Bean
public MultipartResolver multipartResolver(){
CommonsMultipartResolver commonsMultipartResolver = new CommonsMultipartResolver();
return commonsMultipartResolver;
}
/**
* 3.view-controller
* @param registry
*/
@Override
public void addViewControllers(ViewControllerRegistry registry) {
registry.addViewController("/hello").setViewName("hello");
}
/**
* 8.拦截器
* @param registry
*/
@Override
public void addInterceptors(InterceptorRegistry registry) {
TestInterceptor testInterceptor = new TestInterceptor();
// excludePathPatterns()表示不拦截那个路径
// /** 表示任意层的所有请求
registry.addInterceptor(testInterceptor).addPathPatterns("/").excludePathPatterns("/**");
}
/**
* 4.default-servlet-handler
* @param configurer
*/
@Override
public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
configurer.enable();
}
//配置生成模板解析器
@Bean //加上这个注解的方法的返回值就是IOC容器的一个bean
public ITemplateResolver templateResolver() {
WebApplicationContext webApplicationContext = ContextLoader.getCurrentWebApplicationContext();
// ServletContextTemplateResolver需要一个ServletContext作为构造参数,可通过WebApplicationContext 的方法获得
ServletContextTemplateResolver templateResolver = new ServletContextTemplateResolver(webApplicationContext.getServletContext());
templateResolver.setPrefix("/WEB-INF/templates/");
templateResolver.setSuffix(".html");
templateResolver.setCharacterEncoding("UTF-8");
templateResolver.setTemplateMode(TemplateMode.HTML);
return templateResolver;
}
//生成模板引擎并为模板引擎注入模板解析器
@Bean
public SpringTemplateEngine templateEngine(ITemplateResolver templateResolver) {
SpringTemplateEngine templateEngine = new SpringTemplateEngine();
templateEngine.setTemplateResolver(templateResolver);
return templateEngine;
}
//生成视图解析器并未解析器注入模板引擎
@Bean
public ViewResolver viewResolver(SpringTemplateEngine templateEngine) {
ThymeleafViewResolver viewResolver = new ThymeleafViewResolver();
viewResolver.setCharacterEncoding("UTF-8");
viewResolver.setTemplateEngine(templateEngine);
return viewResolver;
}
}
3、创建SpringConfig配置类,代替spring的配置文件
@Configuration
public class SpringConfig {
//ssm整合之后,spring的配置信息写在此类中
}