注解配置SpringMVC
使用配置类和注解代替web.xml和SpringMVC配置文件的功能
创建初始化类,代替web.xml
在Servlet3.0环境中,容器会在类路径中查找实现 javax.servlet.ServletContainerInitializer 接口的类,如果找到的话就用它来配置 Servlet容器 == web.xml的功能
Spring提供了这个接口的实现,名为 SpringServletContainerInitializer,这个类反过来又会查找实现 WebApplicationInitializer 的类并将配置的任务交给它们来完成。
Spring3.2引入了一个便利的 WebApplicationInitializer 基础实现
名为 AbstractAnnotationConfigDispatcherServletInitializer
继承该类并部署到 TOMCAT中 == 代替 web.xml
当我们的类扩展了 AbstractAnnotationConfigDispatcherServletInitializer 并将其部署到Servlet3.0容器的时候容器会自动发现它,并用它来配置Servlet上下文。
public class WebInit extends AbstractAnnotationConfigDispatcherServletInitializer {
@Override
// 1.设置配置类,代替spring的配置文件
protected Class<?>[] getRootConfigClasses() {
return new Class[]{SpringConfig.class};
}
@Override
// 2.设置配置类,代替springMVC的配置文件
protected Class<?>[] getServletConfigClasses() {
return new Class[]{WebConfig.class};
}
@Override
// 3.设置SpringMVC的前端控制器 DispatcherServlet的 url-pattern
protected String[] getServletMappings() {
return new String[]{"/"};
}
@Override
//Ctrl+o 查看可以重写的抽象方法
// 4.设置当前的过滤器
protected Filter[] getServletFilters() {
//创建编码过滤器 CharacterEncodingFilter
CharacterEncodingFilter characterEncodingFilter = new CharacterEncodingFilter();
characterEncodingFilter.setEncoding("UTF-8");
characterEncodingFilter.setForceEncoding(true);
//创建处理请求方式的过滤器 HiddenHttpMethodFilter
HiddenHttpMethodFilter hiddenHttpMethodFilter = new HiddenHttpMethodFilter();
return new Filter[] {characterEncodingFilter, hiddenHttpMethodFilter};
}
}
创建SpringConfig配置类,代替spring的配置文件
@Configuration //将类标识位配置类
public class SpringConfig {
//SSM整合后,spring的配置文件写在此类中
}
创建WebConfig配置类,代替SpringMVC的配置文件
代替 SpringMVC的配置文件 springmvc.xml 的内容:
扫描组件、视图解析器、默认的Servlet处理静态资源、mvc的注解驱动、视图控制器、文件上传解析器、拦截器、异常解析器
@Configuration
@ComponentScan("com.zzz.controller") // 1.扫描组件
@EnableWebMvc // 4.开启mvc的注解驱动
public class WebConfig implements WebMvcConfigurer {
@Override // 3.默认的Servlet处理静态资源
public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
configurer.enable(); //开启默认的Servlet
}
@Override
public void addViewControllers(ViewControllerRegistry registry) {
// 5.视图控制器,所有 "/" 请求都直接跳转到 逻辑视图 "index"
registry.addViewController("/").setViewName("index");
}
//如何在类中配置 bean -- 方法的返回值为 bean的类型
@Bean // 该注解可以将方法的返回值作为 bean进行管理,bean的id就是方法名
public CommonsMultipartResolver multipartResolver(){
// 6.文件上传解析器
return new CommonsMultipartResolver();
}
@Override
public void addInterceptors(InterceptorRegistry registry) {
// 7.拦截器
FirstInterceptor firstInterceptor = new FirstInterceptor();
//拦截除了 /test 外的所有请求
registry.addInterceptor(firstInterceptor).addPathPatterns("/**").excludePathPatterns("/test");
}
@Override
public void configureHandlerExceptionResolvers(List<HandlerExceptionResolver> resolvers) {
// 8.异常解析器
SimpleMappingExceptionResolver exceptionResolver = new SimpleMappingExceptionResolver();
Properties properties = new Properties();
// properties中,key = 处理的异常, value = 跳转的页面的逻辑视图
properties.setProperty("java.lang.ArithmeticException","error");
exceptionResolver.setExceptionMappings(properties);
exceptionResolver.setExceptionAttribute("ex");
resolvers.add(exceptionResolver);
}
// 2.Thymeleaf 视图解析器 固定格式
//配置生成模板解析器
@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;
}
}
标签:解析器,return,SpringMVC,SpringMVC12,templateResolver,new,Override,注解,public
From: https://www.cnblogs.com/Ashen-/p/17131168.html