1. 程式人生 > 其它 >Day07(Spring_MVC攔截器interceptor)47

Day07(Spring_MVC攔截器interceptor)47

SpringMVC攔截器

1. SpringMVC攔截器

1.1 攔截器(interceptor)的作用

Spring MVC 的攔截器類似於 Servlet 開發中的過濾器 Filter,用於對處理器進行預處理和後處理。

將攔截器按一定的順序聯結成一條鏈,這條鏈稱為攔截器鏈(Interceptor Chain)。在訪問被攔截的方法或欄位時,攔截器鏈中的攔截器就會按其之前定義的順序被呼叫。攔截器也是AOP思想的具體實現。

1.2 攔截器和過濾器區別

區別過濾器攔截器
使用範圍 是 servlet 規範中的一部分,任何 Java Web 工程都可以使用 是 SpringMVC 框架自己的,只有使用了 SpringMVC 框架的工程才能用
攔截範圍 在 url-pattern 中配置了/*之後,可以對所有要訪問的資源攔截 只會攔截訪問的控制器方法,如果訪問的是 jsp,html,css,image 或者 js 是不會進行攔截的

1.3 攔截器的快速入門

自定義攔截器很簡單,只有如下三步:

  1. 建立攔截器類實現HandlerInterceptor介面

  2. 配置攔截器

  3. 測試攔截器的攔截效果

1. 建立攔截器類實現HandlerInterceptor介面

public class MyHandlerInterceptor1 implements HandlerInterceptor {
public boolean preHandle(HttpServletRequest request, HttpServletResponse
response, Object handler) {
System.out.println("preHandle running...");
return true;
}
public void postHandle(HttpServletRequest request, HttpServletResponse
response, Object handler, ModelAndView modelAndView) {
System.out.println("postHandle running...");
}
public void afterCompletion(HttpServletRequest request, HttpServletResponse
response, Object handler, Exception ex) {
System.out.println("afterCompletion running...");
}
}

2. 配置攔截器

<!--配置攔截器-->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean class="com.itheima.interceptor.MyHandlerInterceptor1"/>
</mvc:interceptor>
</mvc:interceptors>

3. 測試攔截器的攔截效果(編寫目標方法)

@RequestMapping("/quick23")
@ResponseBody
public ModelAndView quickMethod23() throws IOException, ParseException {
System.out.println("目標方法執行....");
ModelAndView modelAndView = new ModelAndView();
modelAndView.addObject("name","itcast");
modelAndView.setViewName("index");
return modelAndView;
}

測試攔截器的攔截效果(訪問網址)

http://localhost:8080/itheima_springmvc1/quick23

控制檯列印結果

1.4 多攔截器操作

同上,在編寫一個MyHandlerInterceptor2操作,測試執行順序

1.5 攔截器方法說明

方法名說明
preHandle() 方法將在請求處理之前進行呼叫,該方法的返回值是布林值Boolean型別的,當它返回為false 時,表示請求結束,後續的Interceptor 和Controller 都不會再執行;當返回值為true 時就會繼續呼叫下一個Interceptor 的preHandle 方法
postHandle() 該方法是在當前請求進行處理之後被呼叫,前提是preHandle 方法的返回值為true 時才能被呼叫,且它會在DispatcherServlet 進行檢視返回渲染之前被呼叫,所以我們可以在這個方法中對Controller 處理之後的ModelAndView 物件進行操作
afterCompletion() 該方法將在整個請求結束之後,也就是在DispatcherServlet 渲染了對應的檢視之後執行,前提是preHandle 方法的返回值為true 時才能被呼叫

1.6 知識要點

自定義攔截器步驟

  1. 建立攔截器類實現HandlerInterceptor介面

  2. 配置攔截器

  3. 測試攔截器的攔截效果

1.7 案例-使用者登入許可權控制

需求:使用者沒有登入的情況下,不能對後臺選單進行訪問操作,點選選單跳轉到登入頁面,只有使用者登入成功後才能進行後臺功能的操作