Filter&Listener(过滤器和监听器)

简介: Java中的过滤器(Filter)和监听器(Listener)是两种不同的概念。过滤器(Filter)是在Java Web应用程序中,用来拦截和修改进入或离开web应用程序的请求和响应的对象。监听器(Listener)是一种用于监听和响应特定事件的Java对象。

1、什么是Filter

  • 概念:Filter 表示过滤器,是 JavaWeb 三大组件(Servlet(主要)、Filter(辅助)、Listener(辅助))之一。
  • 作用:过滤器可以把对资源的请求拦截下来,从而实现一些特殊的通用操作功能
    • 统一编码处理
    • VIP功能
    • 敏感字处理(例如:打游戏时候发的信息展示结果 我*你*)

image-20240121101601279

2、Filter快速入门

1、首先创建一个filter-listeren的web项目,然后在项目中添加一个servlet(充当web资源)

@WebServlet(value = "/demo")
public class Demo1Servlet extends HttpServlet {
   
   
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
   
   
        System.out.println("demo1请求");

    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
   
   
        request.setCharacterEncoding("UTF-8");
    }
}

2、 定义类,实现 Filter接口,并重写其所有方法,配置Filter拦截资源的路径:在类上定义 @WebFilter 注解

/**
 * WebFilter    表示定义一个过滤器
 *  /*          表示对所有发送的请求进行拦截
 */
@WebFilter("/*")
public class Demo1filter implements Filter {
   
   


    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
   
   

    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
   
   
    }

    @Override
    public void destroy() {
   
   

    }
}

3、在doFilter方法中输出一句话,并放行

/**
     * 过滤器中的过滤方法
     * @param servletRequest
     * @param servletResponse
     * @param filterChain
     * @throws IOException
     * @throws ServletException
     */
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
   
   
    //放行前代码
    System.out.println("demo1放行前代码");

    //放行
    filterChain.doFilter(servletRequest,servletResponse);

    //放行后代码
    System.out.println("demo1放行后代码");
}

3、Filter执行流程

通过快速入门的结果我们发现Filter的执行流如下:

image-20240121105418161

从中可以发现规律:

1.访问web资源的时候首先会经过过滤器执行放行前代码

  1. 然后再访问web资源
  2. 最后再返回到过滤器执行放行后代码

思考:

  • 放行后访问对应资源,资源访问完成后,还会回到Filter中吗?
    如果回到Filter中,是重头执行还是执行放行后的逻辑呢?

  • 如果回到Filter中,是重头执行还是执行放行后的逻辑呢?

    放行后逻辑
    

4、Filter使用细节

4.1、Filter 拦截路径配置

疑问:浏览器访问目标资源的路径,如果目标地址不存在,过滤器会不会运行?

如果请求的URL地址不存在,但是匹配过滤的地址,还是会执行过滤器

Filter 可以根据需求,配置不同的拦截资源路径

//@WebFilter(value = "/index.jsp")
//@WebFilter(value = "/user/*")
//@WebFilter(value = "*.jsp")
@WebFilter(value = "/*")
public class Demo1Filter implements Filter
  • 拦截具体的资源:/index.jsp:只有访问index.jsp时才会被拦截。
  • 目录拦截:/user/*:访问/user下的所有资源,都会被拦截
  • 后缀名拦截:*.jsp:访问后缀名为jsp的资源,都会被拦截
  • 拦截所有:/*:访问所有资源,都会被拦截

4.2、过滤器链

一个Web应用,可以配置多个过滤器,这多个过滤器称为过滤器链

image-20221102204934232

:注解配置的Filter,优先级按照过滤器类名(字符串)的自然排序

4.3、XML配置Filter

步骤

  • 1.创建Filetr实现类
public class Demo1filter implements Filter {
   
   

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
   
   

    }

    /**
     * 过滤器中的过滤方法
     * @param servletRequest
     * @param servletResponse
     * @param filterChain
     * @throws IOException
     * @throws ServletException
     */
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
   
   
        //放行前代码
        System.out.println("demo1放行前代码");

        //放行
        filterChain.doFilter(servletRequest,servletResponse);

        //放行后代码
        System.out.println("demo1放行后代码");
    }

    @Override
    public void destroy() {
   
   

    }
}
    1. 配置Filter拦截资源的路径:在web.xml中配置
<filter>
    <filter-name>demo1</filter-name>
    <filter-class>com.demo.filter.Demo1filter</filter-class>
</filter>
<filter-mapping>
    <filter-name>demo1</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

发现XML配置的过滤器链,按照< filter-mapping>配置的先后顺序

5、Listener

  • 概念:Listener 表示监听器,是 JavaWeb 三大组件(Servlet、Filter、Listener)之一。
  • 监听器可以监听就是在application,session,request三个对象创建、销毁或者往其中添加修改删除属性时自动执行代码的功能组件
  • Listener分类:JavaWeb中提供了8个监听器

image-20221102214313741

ServletContextListener 使用

  1. 定义类,实现ServletContextListener接口

  2. 在类上添加@WebListener 注解

@WebListener
public class Demo1Listener implements ServletContextListener {
   
   
    /**
     * servletContext对象被创建,整个web应用发布成功
     * @param sce
     */
    @Override
    public void contextInitialized(ServletContextEvent sce) {
   
   
        System.out.println("程序启动");//创建mysql连接池以及创建线程池
    }
    /**
     * servletContext对象销毁,整个web应用卸载
     * @param sce
     */
    @Override
    public void contextDestroyed(ServletContextEvent sce) {
   
   
        System.out.println("程序关闭");//关闭mysql连接池以及创建线程池
    }
}

启动程序结果

image-20221102214817872

说明程序启动的时候调用了contextInitialized方法

重启程序结果

image-20221102214912961

说明程序关闭的时候调用了contextDestroyed方法

相关文章
|
6月前
|
XML Java 应用服务中间件
Listener(监听器)
Listener(监听器)
81 4
|
6月前
|
Java 程序员 应用服务中间件
JavaWeb之过滤器(Filter)与监听器(Listener)
本文介绍了JavaWeb中的过滤器(Filter)和监听器(Listener)概念及其使用。过滤器主要用于拦截和处理Web资源请求,如进行编码设置、权限验证等,它在Servlet之前和之后执行。监听器则监听域对象(如ServletRequest、HttpSession、ServletContext)状态变化,分为创建/销毁监听和属性变化监听。监听器在Web.xml中注册后会在相应事件发生时自动执行,例如用于统计网站访问人数或初始化配置。
|
6月前
javaWeb监听器Listener -自定义监听器类实现
javaWeb监听器Listener -自定义监听器类实现
Listener 监听器
监听器是专门用于对其他对象身上发生的事件或状态改变进行监听和相应处理的对象,当被监视的对象发生情况时,立即采取相应的行动。Servlet监听器:Servlet规范中定义的一种特殊类,它用于监听Web应用程序中的ServletContext,HttpSession和HttpServletRequest等域对象的创建与销毁事件,以及监听这些域对象中的属性发生修改的事件。
|
6月前
|
缓存 Java Spring
servlet/filter/listener/interceptor区别与联系
servlet/filter/listener/interceptor区别与联系
71 0
|
Java 应用服务中间件 Spring
@RefreshScope和过滤器Filter不要这样用
在注册自定义的OncePerRequestFilter所在的类上加了@RefreshScope导致自定义的OncePerRequestFilter不会被注册到上下文。
|
Java 应用服务中间件 数据库连接
Filter&Listener
Filter&Listener
|
设计模式 监控 前端开发
JavaWeb中的Filter过滤器和Listener监听器
JavaWeb中的Filter过滤器和Listener监听器
|
存储 Java 数据安全/隐私保护
servlet过滤器与监听器
前言 Servlet 过滤器和监听器是 Java Web 应用程序中常见的两种组件,它们提供了各种扩展 Web 应用程序功能的方式。 总的来说,过滤器和监听器都可以通过 Java Web 应用程序的配置文件或注解进行使用,方便灵活,并可以很好地实现框架与业务逻辑的分离,提高代码可维护性和扩展性。 过滤器(Filter) 1. 参数验证和转换:可以拦截用户提交的数据,并对数据格式进行验证、修正或转换。 2. 访问控制和认证:可以拦截请求并检查用户是否有访问特定资源的权限。 3. 日志记录:可以拦截请求并输出相应的日志信息,用于系统运行时的监测与故障排除。 4. 资源压缩和解密: 可以拦截响应并对
82 0
|
人工智能 安全 Java
Java里面的过滤器Filter,监听器Listener和拦截器Interceptor的区别
Java里面的过滤器Filter,监听器Listener和拦截器Interceptor的区别