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

 

 

 

 

 

 

 

 

 

posted @ 2020-09-02 20:53  why666  阅读(275)  评论(0编辑  收藏  举报