八.spring攔截器和的過濾器
阿新 • • 發佈:2020-09-02
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>