过滤器与拦截器的区别

1.过滤器:
斜体样式依赖于servlet容器。在实现上基于函数回调,可以对几乎所有请求进行过滤,但是缺点是一个过滤器实例只能在容器初始化时调用一次。使用过滤器的目的是用来做一些过滤操作,获取我们想要获取的数据,比如:在过滤器中修改字符编码;在过滤器中修改HttpServletRequest的一些参数,包括:过滤低俗文字、危险字符等
2.拦截器:
依赖于web框架,在SpringMVC中就是依赖于SpringMVC框架。在实现上基于Java的反射机制,属于面向切面编程(AOP)的一种运用。由于拦截器是基于web框架的调用,因此可以使用Spring的依赖注入(DI)进行一些业务操作,同时一个拦截器实例在一个controller生命周期之内可以多次调用。
但是缺点是只能对controller请求进行拦截,对其他的一些比如直接访问静态资源的请求则没办法进行拦截处理

3.过滤器和拦截器的区别:
①拦截器是基于java的反射机制的,而过滤器是基于函数回调。
②拦截器不依赖与servlet容器,过滤器依赖与servlet容器。
③拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用。
④拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。
⑤在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次。
⑥拦截器可以获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,可以调用业务逻辑。过滤器

@Override

    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {
        System.out.println("before...");
        chain.doFilter(request, response);
        System.out.println("after...");
    }
/**
chain.doFilter(request, response);
这个方法的调用作为分水岭。事实上调用Servlet的doService()方法是在
chain.doFilter(request, response);
这个方法中进行的。拦截器拦截器是被包裹在过滤器之中的。
*/
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)throws Exception {
        System.out.println("preHandle");
        returntrue;
        }
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView)throws Exception {
        System.out.println("postHandle");
        }
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)throws Exception {
        System.out.println("afterCompletion");
        }

a.
·preHandle()这个方法是在过滤器的chain.doFilter(request, response)方法的前一步执行,也就是在 [System.out.println(“before…”)][chain.doFilter(request, response)]之间执行。  
b.
preHandle()方法之后,在return ModelAndView之前进行,可以操控Controller的ModelAndView内容。  
c.
afterCompletion()方法是在过滤器返回给前端前一步执行,也就是在[chain.doFilter(request, response)][System.out.println(“after…”)]之间执行。  
SpringMVC的机制是由同一个Servlet来分发请求给不同的Controller,其实这一步是在Servlet的service()方法中执行的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Servlet过滤器拦截器Java Web开发中常用的组件,用于在请求处理流程中进行预处理或后处理操作。它们之间的主要区别如下: 1. 运行位置不同: - 过滤器:在Servlet容器中的Servlet调用前后执行,即位于Servlet之前拦截请求或之后拦截响应。 - 拦截器:在DispatcherServlet处理请求前后执行,即位于Controller之前拦截请求或之后拦截响应。 2. 功能不同: - 过滤器:通过在请求处理前后进行过滤,可以修改请求参数、检查用户权限、记录日志等。 - 拦截器:更加专注于请求的处理流程,可以对请求进行控制、修改ModelAndView对象、异常处理等。 3. 使用方式不同: - 过滤器:在web.xml文件中配置过滤器名称及执行顺序,过滤器可以过滤所有的Servlet请求或静态资源请求。 - 拦截器:通过在Spring配置文件中使用<interceptors>标签来配置拦截器拦截器只能拦截Spring MVC中的请求。 4. 生命周期不同: - 过滤器:在Servlet容器启动时创建,随Servlet容器的启停而启停。 - 拦截器:由Spring容器管理,随Spring容器的启停而启停。 综上所述,过滤器既可以拦截Servlet请求也可以拦截静态资源请求,功能更灵活多样;而拦截器专注于对请求处理的控制和修改,灵活性相对较强。在实际应用中,选择使用过滤器还是拦截器,可以根据具体的需求和场景进行合理选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值