1. 引言
攔截器(Interceptor)實現對每一個請求處理前后進行相關的業務處理,類似于Servlet的Filter。
我們可以讓普通的Bean實現HandlerIntercpetor接口或繼承HandlerInterceptorAdapter類來實現自定義攔截器。
通過重寫WebMvcConfigurerAdapter的addIntercetors方法來注冊一個計算每一次請求的處理時間的攔截器。
2. 自定義攔截器的實現
2.1 定義攔截器
新建LogInterceptor類,并繼承HandlerInterceptorAdapter類,重寫preHandle、postHandle這兩個方法。
1.preHandle方法表示在請求發生前執行,內容如下:
1
2
3
4
|
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { request.setAttribute("begin", System.currentTimeMillis()); return true; } |
2.postHandle方法表示在請求完成后執行,內容如下:
1
2
3
4
5
6
7
8
|
@Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { long begin = (long)request.getAttribute("begin"); request.removeAttribute("begin"); long end = System.currentTimeMillis(); System.out.println("本次請求消耗時間為:"+new Long(end-begin)+"ms"); } |
2.2 配置攔截器
2.2.1 使用xml配置
1.在配置文件中添加支持MVC的schema
1
2
3
|
xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation=" http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd" |
2.使用mvc:interceptors標簽聲明攔截器
1
2
3
4
5
6
7
8
9
|
< mvc:interceptors > <!-- 使用bean定義一個Interceptor,直接定義在mvc:interceptors根下面的Interceptor將攔截所有的請求 --> < bean class = "org.aming.demo.springmvc.interceptor.LogInterceptor" /> < mvc:interceptor > < mvc:mapping path = "${指定的URL}" /> <!-- 定義在mvc:interceptor下面的表示是對特定的請求才進行攔截的 --> < bean class = "${其他攔截器}" /> </ mvc:interceptor > </ mvc:interceptors > |
說明:沒有測試過!?。?/span>
2.2.2 使用JavaConfig配置
3.配置攔截器的Bean
1
2
3
4
|
@Bean public LogInterceptor logInterceptor() { return new LogInterceptor(); } |
4.重寫addInterceptors方法,注冊攔截器
1
2
3
4
|
@Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(logInterceptor()); } |
說明:配置類需要繼承WebMvcConfigurerAdapter類
3. 運行結果
以上這篇Spring MVC中自定義攔截器的實例講解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:http://www.cnblogs.com/xiao2/p/7412389.html