八.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>

浙公网安备 33010602011771号