Java 拦截器、过滤器和监听器的区别与作用


Java 拦截器、过滤器和监听器是在 Java Web 开发中常用的组件,它们各有特点和用途。下面将分别介绍它们的区别和作用,并提供具体的代码示例。

一、定义与区别

  • 拦截器:基于 Java 的反射机制,属于 AOP(面向切面编程)思想的应用。在 Spring 等框架中广泛应用,主要用于拦截用户请求,在目标方法执行前后进行自定义逻辑处理。

  • 过滤器:由 Servlet 容器调用,可用于拦截请求和响应。在请求处理之前或之后执行代码,如编码转换、权限验证等。

  • 监听器:用于监听某些事件的发生,如 ServletContext、HttpSession 和 ServletRequest 等。在特定事件触发时执行逻辑,如统计在线人数。

它们的主要区别如下:

组件基于技术拦截范围生命周期管理
拦截器反射机制(AOP)框架中的方法调用(如 Spring)由框架管理
过滤器Servlet 容器客户端请求和服务器响应由 Servlet 容器管理
监听器事件监听机制应用程序事件(如会话创建)由 Servlet 容器管理

二、具体用途与作用

1. 拦截器

  • 用途:用于执行跨横切逻辑,如日志记录、权限检查、性能监控等。
  • 作用:在请求处理的各个阶段(如请求前、请求后、异常处理后)执行自定义逻辑。

代码示例

import org.springframework.web.servlet.HandlerInterceptor;

public class MyInterceptor implements HandlerInterceptor {
    // 在请求处理之前执行
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
        System.out.println("请求处理前执行");
        return true; // 返回 false 可以阻止请求继续处理
    }

    // 在请求处理之后执行
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) {
        System.out.println("请求处理后执行");
    }

    // 在整个请求完成之后执行
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {
        System.out.println("请求处理完成执行");
    }
}

在 Spring 配置文件中注册拦截器:

<mvc:interceptors>
    <bean class="com.example.MyInterceptor"/>
</mvc:interceptors>

2. 过滤器

  • 用途:用于对请求和响应进行预处理和后处理,如编码转换、权限验证、日志记录等。
  • 作用:在请求到达 Servlet 之前或响应返回客户端之前进行处理。

代码示例

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;

public class MyFilter implements Filter {
    // 过滤器初始化
    @Override
    public void init(FilterConfig filterConfig) {
        System.out.println("过滤器初始化");
    }

    // 拦截请求和响应
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) {
        System.out.println("请求前处理");
        chain.doFilter(request, response); // 放行请求
        System.out.println("响应后处理");
    }

    // 过滤器销毁
    @Override
    public void destroy() {
        System.out.println("过滤器销毁");
    }
}

web.xml 中配置过滤器:

<filter>
    <filter-name>myFilter</filter-name>
    <filter-class>com.example.MyFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>myFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

3. 监听器

  • 用途:用于监听应用程序事件,如会话创建、销毁、属性变更等。
  • 作用:在特定事件发生时执行逻辑,如统计在线人数、初始化资源等。

代码示例

import javax.servlet.http.HttpSessionListener;
import javax.servlet.http.HttpSessionEvent;

public class MyListener implements HttpSessionListener {
    private static int onlineCount = 0;

    // 会话创建时触发
    @Override
    public void sessionCreated(HttpSessionEvent se) {
        onlineCount++;
        System.out.println("会话创建,当前在线人数:" + onlineCount);
    }

    // 会话销毁时触发
    @Override
    public void sessionDestroyed(HttpSessionEvent se) {
        onlineCount--;
        System.out.println("会话销毁,当前在线人数:" + onlineCount);
    }
}

web.xml 中配置监听器:

<listener>
    <listener-class>com.example.MyListener</listener-class>
</listener>

三、总结

  • 拦截器:适合处理与业务逻辑相关的横切关注点,如权限验证、日志记录等。
  • 过滤器:更贴近网络层,适合对请求和响应进行预处理和后处理,如编码转换、安全过滤等。
  • 监听器:用于监听特定事件的发生,适合需要在特定事件发生时执行逻辑的场景,如统计在线人数、资源初始化等。

根据实际需求选择合适的组件,可以更好地组织代码和提高开发效率。

如果大家对 Java Web 开发中的其他知识点感兴趣,欢迎在评论区留言讨论!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java皇帝

有帮助就赏点吧,博主点杯水喝喝

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值