SpringMVC使用註解配置方式
SpringMVC註解配置方式
使用配置類和註解代替web.xml和SpringMVC配置文件的功能。
一、創建初始化類
在 Servlet3.0 環境中,容器會在類路徑中查找實現javax.servlet.ServletContainerInitializer接口的類,如果找到的話就用它來配置 Servlet 容器。
Spring 提供瞭這個接口的實現,名為SpringServletContainerInitializer,這個類反過來又會查找實現WebApplicationInitializer的類並將配置的任務交給它們來完成。
Spring3.2 引入瞭一個便利的WebApplicationInitializer基礎實現,名為AbstractAnnotationConfigDispatcherServletInitializer,
當我們的類擴展瞭AbstractAnnotationConfigDispatcherServletInitializer並將其部署到 Servlet3.0 容器的時候,容器會自動發現它,並用它來配置 Servlet 上下文。
這裡新建一個工程來演示。
pom.xml裡的依賴可以復制之前的內容,web.xml 和 SpringMVC 已經不需要再進行創建瞭。
package com.pingguo.mvc.config; import org.springframework.web.filter.CharacterEncodingFilter; import org.springframework.web.filter.HiddenHttpMethodFilter; import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer; import javax.servlet.Filter; 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[]{WebConfig.class}; } /** * 指定DispatcherServlet的映射規則,即url-pattern * @return */ @Override protected String[] getServletMappings() { return new String[]{"/"}; } /** * 添加過濾器 * @return */ @Override protected Filter[] getServletFilters() { CharacterEncodingFilter encodingFilter = new CharacterEncodingFilter(); encodingFilter.setEncoding("UTF-8"); encodingFilter.setForceRequestEncoding(true); HiddenHttpMethodFilter hiddenHttpMethodFilter = new HiddenHttpMethodFilter(); return new Filter[]{encodingFilter, hiddenHttpMethodFilter}; } }
初始化類裡面要指定 spring的配置類、SpringMVC的配置類,給創建出來即可,記得帶上@Configuration註解,標記為配置類。
其實就是把之前各種配置文件裡的內容轉到配置類裡瞭,這些都會在項目啟動時候初始化。另外,返回的都是數組,所以每個類裡都可以返回多個配置。
二、spring的配置類
當使用ssm整合之後,spring的配置信息寫在spring的配置類中,這裡暫時用不到,寫出來無妨。
package com.pingguo.mvc.config; import org.springframework.context.annotation.Configuration; @Configuration public class SpringConfig { }
三、WebConfig 配置類
這個配置類是代替之前 springMVC.xml 配置文件裡的內容:
- 掃描組件
- 視圖解析器
- view-controller
- default-servlet-handler
- mvc註解驅動
- 文件上傳解析器
- 異常處理
- 攔截器
// 標識當前類為配置類 @Configuration // 掃描組件 @ComponentScan("com.pingguo.mvc") // mvc 註解驅動 @EnableWebMvc public class WebConfig { //配置生成模板解析器 @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; } }
有瞭這幾樣,就可以寫一個index頁面測試一下瞭,寫出頁面和controller類。
<!DOCTYPE html> <html lang="en" xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>index首頁</title> </head> <body> <h1>首頁</h1> </body> </html>
控制器:
@Controller public class TestController { @RequestMapping("/") public String index() { return "index"; } }
設置下部署,啟動可以打開首頁。
剩餘配置
接下來,需要 WebConfig 類實現一個接口WebMvcConfigurer,來重寫裡面的方法。
配置 default-servlet-handler
@EnableWebMvc public class WebConfig implements WebMvcConfigurer { //使用默認的servlet處理靜態資源 default-servlet-handler public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) { configurer.enable(); } ... ...
配置 攔截器
繼續增加。
... ... //配置攔截器 public void addInterceptors(InterceptorRegistry registry) { TestInterceptor firstInterceptor = new TestInterceptor(); registry.addInterceptor(firstInterceptor).addPathPatterns("/**"); } ... ...
攔截器還是要像之前的那樣創建,這裡就創建瞭一個攔截器 TestInterceptor :
public class TestInterceptor implements HandlerInterceptor { public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { return true; } public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { } }
配置 view-controller
當僅做視圖跳轉時候可以使用這個配置。
//配置視圖控制 public void addViewControllers(ViewControllerRegistry registry) { registry.addViewController("/").setViewName("index"); }
配置文件上傳解析器
... ... //配置文件上傳解析器 @Bean public MultipartResolver multipartResolver(){ CommonsMultipartResolver commonsMultipartResolver = new CommonsMultipartResolver(); return commonsMultipartResolver; } ... ...
配置異常處理
//配置異常映射 public void configureHandlerExceptionResolvers(List<HandlerExceptionResolver> resolvers) { SimpleMappingExceptionResolver exceptionResolver = new SimpleMappingExceptionResolver(); Properties prop = new Properties(); prop.setProperty("java.lang.ArithmeticException", "error"); //設置異常映射 exceptionResolver.setExceptionMappings(prop); //設置共享異常信息的鍵 exceptionResolver.setExceptionAttribute("ex"); resolvers.add(exceptionResolver); }
裡面的功能與之前使用配置文件實現的一樣,可以逐一測試一下。
以上就是SpringMVC使用註解配置方式的詳細內容,更多關於SpringMVC註解配置的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- SpringMVC視圖轉發重定向區別及控制器詳解
- SpringMVC RESTFul實戰案例訪問首頁
- SpringMVC實現文件上傳下載的全過程
- 關於SpringMVC對Restful風格的支持詳解
- SpringBoot中的PUT和Delete請求使用