1. 程式人生 > 實用技巧 >八.spring攔截器和的過濾器

八.spring攔截器和的過濾器

1.概念

過濾器

  • servlet規範中的一部分,任何java web工程都可以使用

  • 在url-pattern中配置了/*之後,可以對所有要訪問的資源進行攔截

攔截器

  • 攔截器是SpringMVC框架自己的,只有使用了SpringMVC框架的工程才能使用

  • 攔截器只會攔截訪問的控制器方法, 如果訪問的是jsp/html/css/image/js是不會進行攔截的

過濾器與攔截器的區別:攔截器是AOP思想的具體應用。

攔截器的好處就是當我們訪問靜態資源的時候,不會被攔截,直接找靜態資源去了,而過濾器當我們訪問靜態資源的時候,也會走一遍,比較費伺服器。

2.配置和使用

繼承介面interceptor

 //      return true 就會執行下一個攔截器
 //      return false; 不執行 卡住
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws ServletException, IOException {
       // 如果是登陸頁面則放行
       System.out.println("url: " + request.getRequestURI());
       if (request.getRequestURI().contains("login")) {
           
return true; } HttpSession session = request.getSession(); // 如果使用者已登陸也放行 if(session.getAttribute("user") != null) { return true; } // 使用者沒有登陸跳轉到登陸頁面 request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response); return
false; } public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception { } public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception { } }

將攔截器再放到IOC容器

<!--配置自己的攔截器-->
<mvc:interceptors>
<mvc:interceptor>
<!-- 配置攔截的路徑 /** 會攔截一個請求下面的所有東西,如/admin/password/username-->
<mvc:mapping path="/**"/>
<bean class="com.why.config.TestInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>