過濾器 ;spring攔截器 切片 小結
阿新 • • 發佈:2018-06-16
進入 mod req fff bubuko http @override 進行 配置
1. springMVc的攔截器
實現HandlerInterceptor接口,如下: public class HandlerInterceptor1 implements HandlerInterceptor { // controller執行後且視圖返回後調用此方法 // 這裏可得到執行controller時的異常信息 // 這裏可記錄操作日誌 @Override public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3) throws Exception { System.out.println("HandlerInterceptor1....afterCompletion"); } // controller執行後但未返回視圖前調用此方法 // 這裏可在返回用戶前對模型數據進行加工處理,比如這裏加入公用信息以便頁面顯示 @Override public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3) throws Exception { System.out.println("HandlerInterceptor1....postHandle"); } // Controller執行前調用此方法 // 返回true表示繼續執行,返回false中止執行 // 這裏可以加入登錄校驗、權限攔截等 @Override public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object handler) throws Exception { System.out.println("HandlerInterceptor1....preHandle"); HandlerMethod handlerMethod = (HandlerMethod)Handler; ///可以得到攔截器的攔截到的類名 handlerMethod.getBean.getClass().getName();
//得到方法名
handlerMethod。getMethod().getName(); // 設置為true,測試使用 return true; } } 2. 攔截器配置 在springmvc.xml中配置攔截器 <!-- 配置攔截器 --> <mvc:interceptors> <mvc:interceptor> <!-- 所有的請求都進入攔截器 --> <mvc:mapping path="/**" /> <!-- 配置具體的攔截器 --> <bean class="com.shan.interceptor.HandlerInterceptor1" /> </mvc:interceptor> <mvc:interceptor> <!-- 所有的請求都進入攔截器 --> <mvc:mapping path="/**" /> <!-- 配置具體的攔截器 --> <bean class="cn.sea.interceptor.HandlerInterceptor2" /> </mvc:interceptor> </mvc:interceptors>
3.使用攔截器,檢測每個方法的執行時間
4 過濾器 實現耗時
5. 切片 的使用 實現 耗時
過濾器 ;spring攔截器 切片 小結