1. 程式人生 > >過濾器 ;spring攔截器 切片 小結

過濾器 ;spring攔截器 切片 小結

進入 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攔截器 切片 小結